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

SpringSecurity之权限模块设计

目录

前言

实现思路

代码结构

使用说明


前言

前面我们了解了关于微服务权限设计方案以及J W T的相关介绍,今天我们来聊一下,如何避免自己重复的写相同的代码,一次代码实现,即可完美复制到任何项目中实现权限相关的功能。

实现思路

首先,我们要做的就是先将我们的权限模块的功能了解,要做哪些东西。比如:用户登录、授权、认证、过滤、拦截等等。

我们将内容写完了,还不算完成,要做成可以引入到其他项目中的jar包,我们不能将一些配置项写死,比如:过滤内容、登录路径、退出路径、数据库访问链接等等。

上述文件是要让使用jar包的人灵活的自己配置,可控的来实现他人的高度定制内容!

代码结构

我们看一下我自己实现的权限通用模块的jar包,如下图:

 上图中每一个类的含义如下表所示:

类名含义
TokenWebSecurityConfig
安全配置类(2.7.0之前版本使用的)
TwoWebSecurityConfig
安全配置类(2.7.0之后版本使用的)
SecutityBaseController
测试权限控制类
TokenAuthFilter
授权过滤器
TokenLoginFilter
认证过滤器
PermissionResp
权限响应类
DefaultPasswordEncoder
密码处理工具类
TokenLogoutHandler
退出处理器
TokenManager
token管理工具类
UnauthEntryPoint
未授权统一处理类
实现未授权处理类
SecurityUser
安全用户实体类
SecurityApplication
启动类(打包时可删除此类)

这其中我引入了自己的通用模块中的异常处理、以及一些工具类,这些类在使用过程中,完全可以自己去实现,代码大致相同的内容。没有必要完全照搬我的。自己适用即是最好的。

使用说明

下面的文档适用于readme.md

#工具使用说明使用时需要在启动类扫描你的包路径
## 1、Spring security的使用说明不需要使用Spring security的需要在引入jar报的时候排除相关依赖<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-security</artifactId></dependency>需要引入的,需要添加下面的配置token:# 是否校验token时效性,默认为trueenable: true# 是否校验token,默认为truecheckToken: true# 是否校验登录,默认truecheckLogin: true# 是否校验菜单权限,默认为truecheckPermission: false;# 过期时间(分钟)time: 30# Token 存入缓存的key 后缀oldSuffix: aaa-TOKEN# 刷新Token 存入缓存的key 后缀refSuffix: aaa-REF-TOKEN# Token 编码秘钥signKey: 123456783909823permission:# 保存权限到redis的key后缀,key值为用户登录名userName + "-" + suffixsuffix: aaa-PERMISSIONlogin:# 登录地址url: /aaa/loginloginOut:url: /aaa/loginoutfilterInformation: /ws/**,/swagger-ui.html,/webjars/springfox-swagger-ui/**,/swagger-resources/**,/v2/api-docs/**,/manage/permission/range,favicon.ico,/doc.html,/webjars/**,/swagger-resources/**,/v2/api-docs/**,/configuration/security,/aa/captcha,/user/register将resources/security中的UserDetailsServiceImpl复制到自己的service中,调整具体的实现逻辑# version2.0 : 调整User实体类,增加公司ID、用户UUID、去掉了公交公司ID3.0 : 调整生成token时,增加了companyId和UUID,通过token获取companyId4.0 : SpringSectury调整为2.7版本以上后,TokenWebSecurityConfig设置为过期,使用新的TwoWebSecurityConfig

好了关于通用权限模块设计就到这里!

欢迎点击西方卡片,关注《coder练习生》

http://www.lryc.cn/news/59438.html

相关文章:

  • 002_双指针法
  • 超实用的 Linux 高级命令,程序员一定要懂
  • AI+明厨亮灶智能算法 yolo
  • gRPC-Go源码解读一 客户端请求链路分析
  • Word控件Spire.Doc for .net 功能详解
  • 联想服务器配置RAID
  • C++ 虚函数表
  • rancher2.7丢失集群信息
  • 数据库管理-第六十八期 Oracle 23c的其他(20230417)
  • 精准关键词获取-行业搜索词分析
  • c++学习之c++对c的扩展1
  • Redis锁的租约问题
  • 2023年全国最新高校辅导员精选真题及答案50
  • mall商城之k8s部署-4
  • 使用Go语言打造轻量级Web框架
  • 【开源项目】BallCat 项目脚手架
  • KlayGE-004-InputCaps 例子分析
  • 组装机经验、软硬件故障排除、网络问题
  • 【行为型模式】责任链模式
  • C++命令模式 指挥家:掌控命令模式之美
  • 学会 制作极简搜索浏览器 —— 并将 ChatGPT 接入浏览器
  • NumPy 秘籍中文第二版:六、特殊数组和通用函数
  • 各种交叉编译工具链的区别
  • 密度聚类算法(DBSCAN)实验案例
  • 第07章_面向对象编程(进阶)
  • 异常的讲解(2)
  • jvm内存结构
  • 要刹车?生成式AI迎新规、行业连发ChatGPT“警报”、多国考虑严监管
  • 轻松掌握Qt FTP 机制:实现高效文件传输
  • 用AI帮我写一篇关于FPGA的文章,并推荐最热门的FPGA开源项目