springboot shiro token demo实战项目
2019-04-28 本文已影响377人
灰色调诺言
简介
- shiro 是一个强大且易用的Java安全框架,执行身份验证、授权、密码和会话管理。
Git地址
https://gitee.com/wqrzsy/lp-demo/tree/master/lp-springboot-shiro
更多demo请关注
项目分析
1. 自定义权限注解,支持基于注解和配置表多种方式配置过滤规则
data:image/s3,"s3://crabby-images/c1135/c1135c90f87f91f435e57fc29ae254eae2f7a6f6" alt=""
注解的使用方式
data:image/s3,"s3://crabby-images/6c810/6c810db3d9d0ac92d04bc32f05d2b32147395065" alt=""
配置表方式
data:image/s3,"s3://crabby-images/7cd9c/7cd9cb2820b15058f6064c7ca8650faf508c25ac" alt=""
最后的结果
data:image/s3,"s3://crabby-images/77964/7796450cf6f7b43ed120882d99bc93ef7655ee3b" alt=""
注意:这里的顺序是配置表的配置会覆盖注解的
2. 抽离Session的缓存实现
data:image/s3,"s3://crabby-images/6a5cc/6a5cc8cbe089a3c460a2134eef3207c9471194ab" alt=""
3. 封装校验核心逻辑,抽离业务接口
data:image/s3,"s3://crabby-images/97996/9799647d29190a624d957947ffc22332102eefdb" alt=""
4. InitBean 初始化对象
data:image/s3,"s3://crabby-images/da7da/da7da174ad0d74492a7890e3f448245addb9a784" alt=""
5. 令牌
用令牌的方式代替JsessionID
data:image/s3,"s3://crabby-images/1d2e3/1d2e37fbf49dcb0e01af684942279f2a7c05ae10" alt=""
6. 配置表
shiro:
session:
# session 超时
outTime: 300000
login:
token:
# 令牌有效时间
expireTime: 300000
password:
# 密码有效时间
expireTime: 300000
# 过滤链
filterChains:
- /**
- anon
logging:
config: classpath:logback-boot.xml
7. 测试
http://localhost:8080/swagger-ui.html
demo项目导入
参考: https://www.jianshu.com/p/cd0275a2f5fb
注意:该DEMO可以作为子项目直接集成在项目中
如果这篇文章对你有帮助请给个star
data:image/s3,"s3://crabby-images/04e1d/04e1d2f876f1f848493047440a27af63bebfaef0" alt=""