当前位置: 首页 > wzjs >正文

做微网站就在刚刚武汉宣布最新消息

做微网站,就在刚刚武汉宣布最新消息,外贸网站怎么做推广,网页在线编辑SpringSecurity鉴权 启用方法级安全控制​权限上下文传递工具​自定义权限服务 ss 启用方法级安全控制​ package com.chinabuilder.framework.config;/*** spring security配置*EnableMethodSecurity 用于启用基于方法的权限控制。它的作用是通过 AOP(面向切面编程…

SpringSecurity鉴权

  • 启用方法级安全控制​
  • 权限上下文传递工具​
  • 自定义权限服务 ss

启用方法级安全控制​

package com.chinabuilder.framework.config;/*** spring security配置*@EnableMethodSecurity 用于启用基于方法的权限控制。它的作用是通过 AOP(面向切面编程)在方法调用前后进行安全拦截。**/
@EnableMethodSecurity(prePostEnabled = true, securedEnabled = true)
@Configuration
public class SecurityConfig {
}

权限上下文传递工具​

// 在同一请求链路中 跨层级传递权限标识(如 "system:user:add")。
// 技术原理:
//        基于 RequestContextHolder + ThreadLocal 实现线程隔离的临时存储。
//        数据生命周期与 HTTP 请求绑定(SCOPE_REQUEST)。
//        典型场景:
//        拦截器中解析权限 → 存入上下文 → 业务层/日志中获取。
package com.chinabuilder.framework.security.context;public class PermissionContextHolder
{private static final String PERMISSION_CONTEXT_ATTRIBUTES = "PERMISSION_CONTEXT";public static void setContext(String permission){RequestContextHolder.currentRequestAttributes().setAttribute(PERMISSION_CONTEXT_ATTRIBUTES, permission,RequestAttributes.SCOPE_REQUEST);}public static String getContext(){return Convert.toStr(RequestContextHolder.currentRequestAttributes().getAttribute(PERMISSION_CONTEXT_ATTRIBUTES,RequestAttributes.SCOPE_REQUEST));}
}

自定义权限服务 ss

package com.chinabuilder.framework.web.service;@Service("ss")
public class PermissionService
{/*** 验证用户是否具备某权限** @param permission 权限字符串* @return 用户是否具备某权限*/public boolean hasPermi(String permission){if (StringUtils.isEmpty(permission)){return false;}LoginUser loginUser = SecurityUtils.getLoginUser();if (StringUtils.isNull(loginUser) || CollectionUtils.isEmpty(loginUser.getPermissions())){return false;}PermissionContextHolder.setContext(permission);return hasPermissions(loginUser.getPermissions(), permission);}/*** 验证用户是否不具备某权限,与 hasPermi逻辑相反** @param permission 权限字符串* @return 用户是否不具备某权限*/public boolean lacksPermi(String permission){return hasPermi(permission) != true;}/*** 验证用户是否具有以下任意一个权限** @param permissions 以 PERMISSION_DELIMETER 为分隔符的权限列表* @return 用户是否具有以下任意一个权限*/public boolean hasAnyPermi(String permissions){if (StringUtils.isEmpty(permissions)){return false;}LoginUser loginUser = SecurityUtils.getLoginUser();if (StringUtils.isNull(loginUser) || CollectionUtils.isEmpty(loginUser.getPermissions())){return false;}PermissionContextHolder.setContext(permissions);Set<String> authorities = loginUser.getPermissions();for (String permission : permissions.split(Constants.PERMISSION_DELIMETER)){if (permission != null && hasPermissions(authorities, permission)){return true;}}return false;}/*** 判断用户是否拥有某个角色** @param role 角色字符串* @return 用户是否具备某角色*/public boolean hasRole(String role){if (StringUtils.isEmpty(role)){return false;}LoginUser loginUser = SecurityUtils.getLoginUser();if (StringUtils.isNull(loginUser) || CollectionUtils.isEmpty(loginUser.getUser().getRoles())){return false;}for (SysRole sysRole : loginUser.getUser().getRoles()){String roleKey = sysRole.getRoleKey();if (Constants.SUPER_ADMIN.equals(roleKey) || roleKey.equals(StringUtils.trim(role))){return true;}}return false;}/*** 验证用户是否不具备某角色,与 isRole逻辑相反。** @param role 角色名称* @return 用户是否不具备某角色*/public boolean lacksRole(String role){return hasRole(role) != true;}/*** 验证用户是否具有以下任意一个角色** @param roles 以 ROLE_NAMES_DELIMETER 为分隔符的角色列表* @return 用户是否具有以下任意一个角色*/public boolean hasAnyRoles(String roles){if (StringUtils.isEmpty(roles)){return false;}LoginUser loginUser = SecurityUtils.getLoginUser();if (StringUtils.isNull(loginUser) || CollectionUtils.isEmpty(loginUser.getUser().getRoles())){return false;}for (String role : roles.split(Constants.ROLE_DELIMETER)){if (hasRole(role)){return true;}}return false;}/*** 判断是否包含权限** @param permissions 权限列表* @param permission 权限字符串* @return 用户是否具备某权限*/private boolean hasPermissions(Set<String> permissions, String permission){return permissions.contains(Constants.ALL_PERMISSION) || permissions.contains(StringUtils.trim(permission));}
}
http://www.dtcms.com/wzjs/380116.html

相关文章:

  • 武汉网站设计说网站优化策略分析
  • 医院响应式网站建设方案seo和点击付费的区别
  • 企业网站建设方案撰写如何seo推广
  • 嘉兴市城乡规划建设管理委员会网站成都sem优化
  • 正规做网站公司网络营销战略
  • 芜湖网站建设哪家好网站推广的目的
  • ftp 网站 怎么上传文件如何做优化排名
  • 高要市建设局网站拓客最有效方案
  • 创新网站建设外贸网站建设优化
  • 在哪个网站做外快设计软文代发代理
  • 网站建设是什么语言seo策略分析
  • 珠海企业网站建设公司seo点击优化
  • wordpress首行缩进seo上首页
  • 蓝色风格网站人工在线客服
  • 建设公司网站多少钱如何制作百度网页
  • 互联网投诉中心官网入口seo文章外包
  • 建设网站需要服务器吗windows优化大师卸载不掉
  • 榕江网站建设天津百度seo代理
  • 可以转app的网站怎么做的找文网客服联系方式
  • 网站建设方案标书百度页面推广
  • 深圳宝安网站建设seo快速排名系统
  • 广州网站制作公司郑州企业网络推广外包
  • b2b典型网站商品关键词怎么优化
  • 江苏泰州建设局网站进入百度搜索首页
  • wordpress页面生成二维码宁波seo入门教程
  • seo技术建站培训学校
  • 在线课堂手机网站模板seo搜索引擎优化怎么做
  • 汕尾网站开发武汉seo搜索引擎优化
  • 怎么做福彩网站搜索引擎优化的简称是
  • 建大仁科公司网站软文营销写作技巧有哪些?