Spring AOP 实现用户权限验证

 

每个项目都会有权限管理系统

 

无论你是一个简单的企业站,还是一个复杂到爆的平台级项目,都会涉及到用户登录、权限管理这些必不可少的业务逻辑。有人说,企业站需要什么权限管理阿?那行吧,你那可能叫静态页面,就算这样,但你肯定也会有后台管理及登录功能。

每个项目中都会有这些几乎一样的业务逻辑,我们能不能把他们做成通用的系统呢?

AOP 实现用户权限验证

从零开始学 Java - Spring AOP 拦截器的基本实现这篇文章中,我详细的写了什么是 AOP ? 、 AOP 主要能实现什么功能?

AOP 在实际项目中运用的场景主要有权限管理(Authority Management)、事务管理(Transaction Management)、安全管理(Security)、日志管理(Logging)和调试管理(Debugging)等。

所以,权限验证正好我们可以使用 AOP 来直接实现。具体你项目中权限怎么管理,管理的粒度是什么级别这些完全取决于项目需要,这里完全不做任何的讨论。

先说思路:利用自定义注解及拦截器来在你需要的时候,进行你需要的一些权限认证。这里依然涉及到的有enum(枚举)annotation(自定义注解)及拦截器相关知识,废话不多说,直接开写代码。

开始撸一下代码

**一、建立AuthorityType.java枚举类

 
  1. public enum AuthorityType {
  2.  
  3. // 登录和权限都验证 默认
  4. Validate,
  5.  
  6. // 不验证
  7. NoValidate,
  8.  
  9. // 不验证权限
  10. NoAuthority;
  11. }

这个枚举类的作用,依然是使自定义注解用起来爽到还想要。

二、新建Authority.java自定义注解类

 
  1. import java.lang.annotation.Documented;
  2. import java.lang.annotation.ElementType;
  3. import java.lang.annotation.Retention;
  4. import java.lang.annotation.RetentionPolicy;
  5. import java.lang.annotation.Target;
  6.  
  7. @Retention(RetentionPolicy.RUNTIME)
  8. @Target(ElementType.METHOD)
  9. @Documented
  10. public @interface Authority {
  11. // 默认验证
  12. AuthorityType value() default AuthorityType.Validate;
  13.  
  14. }

三、再建一个AuthorityAnnotationInterceptor.java

 
  1. /**
  2. * 权限认证拦截器
  3. *
  4. */
  5. public class AuthorityAnnotationInterceptor extends HandlerInterceptorAdapter {
  6. @Override
  7. public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
  8. throws Exception {
  9.  
  10. if (handler instanceof HandlerMethod) {
  11. HandlerMethod hm = (HandlerMethod) handler;
  12.  
  13. Class<?> clazz = hm.getBeanType();
  14. Method m = hm.getMethod();
  15. try {
  16. if (clazz != null && m != null) {
  17. boolean isClzAnnotation = clazz.isAnnotationPresent(Authority.class);
  18. boolean isMethondAnnotation = m.isAnnotationPresent(Authority.class);
  19. Authority authority = null;
  20. // 如果方法和类声明中同时存在这个注解,那么方法中的会覆盖类中的设定。
  21. if (isMethondAnnotation) {
  22. authority = m.getAnnotation(Authority.class);
  23. } else if (isClzAnnotation) {
  24. authority = clazz.getAnnotation(Authority.class);
  25. }
  26. int code = -1;
  27. String msg = "";
  28. if (authority != null) {
  29. if (AuthorityType.NoValidate == authority.value()) {
  30. // 标记为不验证,放行
  31. return true;
  32. } else if (AuthorityType.NoAuthority == authority.value()) {
  33. // 不验证权限,验证是否登录
  34. // TODO:
  35. return true;
  36. } else {
  37. // 验证登录及权限
  38. // TODO:
  39.  
  40. code = 1;
  41. msg = "验证成功!";
  42. return true;
  43. }
  44. }
  45.  
  46. // //跳转
  47. // String url = "";
  48. // response.getWriter().write("<script>top.location.href='"
  49. // + url + "'</script>");
  50. // return false;
  51.  
  52. // 未通过验证,返回提示json
  53. Map<String, Object> responseMap = new HashMap<String, Object>();
  54. responseMap.put("code", code);
  55. responseMap.put("msg", msg);
  56. responseMap.put("params", "");
  57. responseMap.put("rows", "");
  58. String json = new Gson().toJson(responseMap);
  59. response.setCharacterEncoding("UTF-8");
  60. response.setContentType("application/json; charset=utf-8");
  61. response.getWriter().write(json);
  62. return false;
  63. }
  64. } catch (Exception e) {
  65. }
  66. }
  67. return false;
  68. }
  69. }

这个类的目的就是在打过Authority标签的方法及类上,进行权限认证。我这里分了三种类型:全部验证、只验证登录、不验证用来满足我们的业务需求。

这里的返回值可以是 JSON 串,也可以是跳转到相应的页面,来实现你想要的效果。

四、配置拦截器

 
  1. <mvc:interceptors>
  2. <!-- 权限认证拦截器 -->
  3. <mvc:interceptor>
  4. <mvc:mapping path="/**"/>
  5. <bean class="cn.mayongfa.interceptor.AuthorityAnnotationInterceptor"></bean>
  6. </mvc:interceptor>
  7. </mvc:interceptors>

/WebContent/WEB-INF/springMVC-servlet.xml文件下的<mvc:interceptors>节点配置就行,这里可以配置具体要拦截的 Url 。

到这里就完成了权限验证的工作了,如何使用呢?

使用就非常简单

因为我们的拦截器配置,然后我们在自定义注解的默认是验证,所以,我们只需要在类名及方法名上打标签就可以。
authority.PNG

当然,你完全是可以在拦截器中设置默认就验证所有请求的,接着设置不验证的请求。
文章的具体的案例,都可以访问我的 Github 看到 https://github.com/mafly/SpringDemo

 

 

 

http://blog.mayongfa.cn/

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值