Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
shengzhang_
sa-token
提交
5f919309
sa-token
项目概览
shengzhang_
/
sa-token
通知
68
Star
16
Fork
4
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
sa-token
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
5f919309
编写于
1月 13, 2021
作者:
R
RockMan
提交者:
Gitee
1月 13, 2021
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
update sa-token-doc/doc/use/route-check.md.
完善新增特性文档
上级
d1d25f4d
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
50 addition
and
0 deletion
+50
-0
sa-token-doc/doc/use/route-check.md
sa-token-doc/doc/use/route-check.md
+50
-0
未找到文件。
sa-token-doc/doc/use/route-check.md
浏览文件 @
5f919309
...
...
@@ -56,9 +56,59 @@ public class MySaTokenConfig implements WebMvcConfigurer {
## 3、让我们利用自定义拦截器做点快活的事情
你可以根据路由划分模块,不同模块不同鉴权
```
java
@Configuration
public
class
MySaTokenConfig
implements
WebMvcConfigurer
{
// 注册sa-token的所有拦截器
@Override
public
void
addInterceptors
(
InterceptorRegistry
registry
)
{
// 根据路由划分模块,不同模块不同鉴权
registry
.
addInterceptor
(
new
SaRouteInterceptor
((
request
,
response
,
handler
)->{
SaRouterUtil
.
match
(
"/user/**"
,
()
->
StpUtil
.
checkPermission
(
"user"
));
SaRouterUtil
.
match
(
"/admin/**"
,
()
->
StpUtil
.
checkPermission
(
"admin"
));
SaRouterUtil
.
match
(
"/goods/**"
,
()
->
StpUtil
.
checkPermission
(
"goods"
));
SaRouterUtil
.
match
(
"/orders/**"
,
()
->
StpUtil
.
checkPermission
(
"orders"
));
SaRouterUtil
.
match
(
"/notice/**"
,
()
->
StpUtil
.
checkPermission
(
"notice"
));
SaRouterUtil
.
match
(
"/comment/**"
,
()
->
StpUtil
.
checkPermission
(
"comment"
));
})).
addPathPatterns
(
"/**"
);
}
}
```
## 4、完整的示例
最终的代码,可能会类似于下面的样子:
```
java
@Configuration
public
class
MySaTokenConfig
implements
WebMvcConfigurer
{
// 注册sa-token的拦截器
@Override
public
void
addInterceptors
(
InterceptorRegistry
registry
)
{
// 自定义验证拦截器
registry
.
addInterceptor
(
new
SaRouteInterceptor
((
request
,
response
,
handler
)
->
{
// 登录验证 -- 拦截所有路由,并排除/user/doLogin 用于开放登录
SaRouterUtil
.
match
(
"/**"
,
"/user/doLogin"
,
()
->
StpUtil
.
checkLogin
());
// 角色认证 -- 以/admin/** 开头的路由,必须具备[admin]角色或者[super-admin]角色才可以通过认证
SaRouterUtil
.
match
(
"/admin/**"
,
()
->
StpUtil
.
checkRoleOr
(
"admin"
,
"super-admin"
));
// 权限认证 -- 不同模块, 校验不同权限
SaRouterUtil
.
match
(
"/user/**"
,
()
->
StpUtil
.
checkPermission
(
"user"
));
SaRouterUtil
.
match
(
"/admin/**"
,
()
->
StpUtil
.
checkPermission
(
"admin"
));
SaRouterUtil
.
match
(
"/goods/**"
,
()
->
StpUtil
.
checkPermission
(
"goods"
));
SaRouterUtil
.
match
(
"/orders/**"
,
()
->
StpUtil
.
checkPermission
(
"orders"
));
SaRouterUtil
.
match
(
"/notice/**"
,
()
->
StpUtil
.
checkPermission
(
"notice"
));
SaRouterUtil
.
match
(
"/comment/**"
,
()
->
StpUtil
.
checkPermission
(
"comment"
));
})).
addPathPatterns
(
"/**"
);
}
}
```
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录