网站首页 > java教程 正文
今天来体验一下SaToken框架提供的另一个重要功能——路由拦截鉴权
这个功能我们几乎所有的项目都会用到。比如对于一个管理系统而言,我们可能只希望开放一个登录接口,其他任何接口都要经过鉴权才允许访问,这样就相对来说比较安全。
该框架路由拦截也是通过注册拦截器实现的,我们新建一个拦截器
@Configuration
public class SaTokenConfigure implements WebMvcConfigurer {
// 注册拦截器
@Override
public void addInterceptors(InterceptorRegistry registry) {
// 注册Sa-Token的路由拦截器
registry.addInterceptor(new SaRouteInterceptor())
.addPathPatterns("/**")
.excludePathPatterns("/user/doLogin");
}
}
这样一个基础的拦截器就建好了,现在除了登录接口其他接口都需要登录后才能访问,启动测试一下。
先执行登录状态检测,再登录,最后再执行登录状态检测
结果很明显,在没有登录的时候,后台会抛出异常,登录之后,就可以正常访问了。真的是简单。
除了基础的鉴权以外,框架还支持自定义认证规则,可以使用函数式的写法来写,比如
@Configuration
public class SaTokenConfigure implements WebMvcConfigurer {
// 注册拦截器
@Override
public void addInterceptors(InterceptorRegistry registry) {
// 注册Sa-Token的路由拦截器
registry.addInterceptor(new SaRouteInterceptor((saRequest, saResponse, handler) -> {
// 登录认证 -- 拦截所有路由,并排除/user/doLogin 用于开放登录
SaRouter.match("/**", "/user/doLogin", r -> StpUtil.checkLogin());
// 角色认证 -- 拦截以 admin 开头的路由,必须具备 admin 角色或者 super-admin 角色才可以通过认证
SaRouter.match("/admin/**", r -> StpUtil.checkRoleOr("admin", "super-admin"));
// 权限认证 -- 不同模块认证不同权限
SaRouter.match("/user/**", r -> StpUtil.checkPermission("user"));
SaRouter.match("/admin/**", r -> StpUtil.checkPermission("admin"));
SaRouter.match("/goods/**", r -> StpUtil.checkPermission("goods"));
SaRouter.match("/orders/**", r -> StpUtil.checkPermission("orders"));
SaRouter.match("/notice/**", r -> StpUtil.checkPermission("notice"));
SaRouter.match("/comment/**", r -> StpUtil.checkPermission("comment"));
// 甚至你可以随意的写一个打印语句
SaRouter.match("/**", r -> System.out.println("----啦啦啦----"));
// 连缀写法
SaRouter.match("/**").check(r -> System.out.println("----啦啦啦----"));
}));
}
}
不仅如此,框架还提供了很多写法,多种匹配规则可以让项目的权限控制到头发丝。
体验到这里,感觉Sa-Token框架提供了太多实用的功能,并且在官方文档上还提供了各种使用方法、集成方法:集成Redis、前后台分离、自定义Token风格、自定义Token前缀、记住我模式、模拟他人 & 身份切换、同端互斥登录、二级认证Http Basic 认证、密码加密、会话治理、全局侦听器、全局过滤器、多账号认证、单点登录等功能都有详细的解决方案。
看到这里我心动了,这稍微加点持久层、前端、代码生成器、工作流、定时任务、基础管理功能,这不就是一个完整的管理框架?
要不要码一个呢[惊喜]
猜你喜欢
- 2024-11-04 【快学springboot】12.实现拦截器
- 2024-11-04 Spring Boot 中的拦截器和过滤器到底有什么区别?
- 2024-11-04 SpringBoot中的过滤器和拦截器有什么区别?
- 2024-11-04 为什么你写的拦截器注入不了Java bean?
- 2024-11-04 使用Spring Cloud Zuul实现过滤器或拦截器功能案例
- 2024-11-04 java服务-springboot拦截器实现用户登录Token及权限校验
- 2024-11-04 JAVAEE就业工程师教程之第4章 Struts2拦截器
- 2024-11-04 Spring框架功能分为哪些模块?(spring框架有哪几部分组成)
- 2024-11-04 高级码农Spring Boot实战进阶之过滤器、拦截器的使用
- 2024-11-04 一个拦截器和一个awk命令,秒查线上超时接口
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)
本文暂时没有评论,来添加一个吧(●'◡'●)