zoukankan      html  css  js  c++  java
  • Spring学习总结(17)——Spring AOP权限管理

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

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

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

    AOP 实现用户权限验证

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

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

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

    开始撸一下代码

    一、建立 AuthorityType.java 枚举类

    public enum AuthorityType {
    
        // 登录和权限都验证 默认
        Validate,
    
        // 不验证
        NoValidate,
    
        // 不验证权限
        NoAuthority;
    }

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

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

    import java.lang.annotation.Documented;
    import java.lang.annotation.ElementType;
    import java.lang.annotation.Retention;
    import java.lang.annotation.RetentionPolicy;
    import java.lang.annotation.Target;
    
    @Retention(RetentionPolicy.RUNTIME)  
    @Target(ElementType.METHOD)
    @Documented
    public @interface Authority {  
        // 默认验证
        AuthorityType value() default AuthorityType.Validate;
    
    }

    三、再建一个 AuthorityAnnotationInterceptor.java 类

    /**
     * 权限认证拦截器
     *
     */
    public class AuthorityAnnotationInterceptor extends HandlerInterceptorAdapter {
        @Override
        public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
            throws Exception {
    
        if (handler instanceof HandlerMethod) {
            HandlerMethod hm = (HandlerMethod) handler;
    
            Class<?> clazz = hm.getBeanType();
            Method m = hm.getMethod();
            try {
                if (clazz != null && m != null) {
                    boolean isClzAnnotation = clazz.isAnnotationPresent(Authority.class);
                    boolean isMethondAnnotation = m.isAnnotationPresent(Authority.class);
                    Authority authority = null;
                    // 如果方法和类声明中同时存在这个注解,那么方法中的会覆盖类中的设定。
                    if (isMethondAnnotation) {
                        authority = m.getAnnotation(Authority.class);
                    } else if (isClzAnnotation) {
                        authority = clazz.getAnnotation(Authority.class);
                    }
                    int code = -1;
                    String msg = "";
                    if (authority != null) {
                        if (AuthorityType.NoValidate == authority.value()) {
                            // 标记为不验证,放行
                            return true;
                        } else if (AuthorityType.NoAuthority == authority.value()) {
                            // 不验证权限,验证是否登录
                            // TODO:
                            return true;
                        } else {
                            // 验证登录及权限
                            // TODO:
    
                            code = 1;
                            msg = "验证成功!";
                            return true;
                        }
                    }
    
                    // //跳转
                    // String url = "";
                    // response.getWriter().write("<script>top.location.href='"
                    // + url + "'</script>");
                    // return false;
    
                    // 未通过验证,返回提示json
                    Map<String, Object> responseMap = new HashMap<String, Object>();
                    responseMap.put("code", code);
                    responseMap.put("msg", msg);
                    responseMap.put("params", "");
                    responseMap.put("rows", "");
                    String json = new Gson().toJson(responseMap);
                    response.setCharacterEncoding("UTF-8");
                    response.setContentType("application/json; charset=utf-8");
                    response.getWriter().write(json);
                    return false;
                }
            } catch (Exception e) {
            }
        }
        return false;
        }   
    }

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

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

    四、配置拦截器

    <mvc:interceptors>
        <!-- 权限认证拦截器 -->
        <mvc:interceptor>
            <mvc:mapping path="/**"/>
            <bean class="cn.mayongfa.interceptor.AuthorityAnnotationInterceptor"></bean>
        </mvc:interceptor>
    </mvc:interceptors>

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

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

    使用就非常简单

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

    当然,你完全是可以在拦截器中设置默认就验证所有请求的,接着设置不验证的请求。

  • 相关阅读:
    【Navicat】查看历史执行的SQL
    什么是webpack模块化构建工具
    靠边的列表如果没有设置margin-left:20px,那么是看不到列表序号的。
    在博客园中复制代码到网页中,有时候会存在异常,如下:
    / WebAPP开发与小程序 / 步骤一 · 4-5 地图搜索与poi结合(2)
    忘记样式属性对应的值时,可以使用以下方法进行操作
    //点击按钮加减音频音量到最小会出现bug什么意思???
    组件化网页开发 3步骤 / 20门课
    position:absolute 按钮左右分布:left:0 和 right:0 以及雪碧图
    查看引入的文件是否成功
  • 原文地址:https://www.cnblogs.com/zhanghaiyang/p/7212884.html
Copyright © 2011-2022 走看看