zoukankan      html  css  js  c++  java
  • Spring MVC拦截器+注解方式实现防止表单重复提交

    原理:在新建页面中Session保存token随机码,当保存时验证,通过后删除,当再次点击保存时由于服务器端的Session中已经不存在了,所有无法验证通过。

    注解Token代码:

    @Target(ElementType.METHOD)

    @Retention (RetentionPolicy.RUNTIME)
    public @interface Token {
     
         boolean save() default false ;
     
         boolean remove() default false ;
    }

    拦截器TokenInterceptor代码:

    public class TokenInterceptor extends HandlerInterceptorAdapter {
     
         @Override
         public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throwsException {
             if (handler instanceof HandlerMethod) {
                 HandlerMethod handlerMethod = (HandlerMethod) handler;
                 Method method = handlerMethod.getMethod();
                 Token annotation = method.getAnnotation(Token. class );
                 if (annotation != null ) {
                     boolean needSaveSession = annotation.save();
                     if (needSaveSession) {
                         request.getSession( false ).setAttribute( "token" , UUID.randomUUID().toString());
                     }
                     boolean needRemoveSession = annotation.remove();
                     if (needRemoveSession) {
                         if (isRepeatSubmit(request)) {
                             return false ;
                         }
                         request.getSession( false ).removeAttribute( "token" );
                     }
                 }
                 return true ;
             else {
                 return super .preHandle(request, response, handler);
             }
         }
     
         private boolean isRepeatSubmit(HttpServletRequest request) {
             String serverToken = (String) request.getSession( false ).getAttribute( "token" );
             if (serverToken == null ) {
                 return true ;
             }
             String clinetToken = request.getParameter( "token" );
             if (clinetToken == null ) {
                 return true ;
             }
             if (!serverToken.equals(clinetToken)) {
                 return true ;
             }
             return false ;
         }
    }

    然后在Spring MVC的配置文件里加入:

    <!-- 拦截器配置 -->
    < mvc:interceptors >
         <!-- 配置Shiro拦截器,实现注册用户的注入 -->
         < mvc:interceptor >
             < mvc:mapping path = "/**" />
             < bean class = "com.storezhang.video.shiro.ShiroInterceptor" />
         </ mvc:interceptor >
         <!-- 配置Token拦截器,防止用户重复提交数据 -->
         < mvc:interceptor >
             < mvc:mapping path = "/**" />
             < bean class = "com.storezhang.web.spring.TokenInterceptor" />
         </ mvc:interceptor >
    </ mvc:interceptors >

    相关代码已经注释,相信你能看懂。
    关于这个方法的用法是:在需要生成token的controller上增加@Token(save=true),而在需要检查重复提交的controller上添加@Token(remove=true)就可以了。
    另外,你需要在view里在form里增加下面代码:

    <     input     type     =     "hidden"     name     =     "token"     value     =     "${token}"     />

    已经完成了,去试试看你的数据还能重复提交了吧。

  • 相关阅读:
    CSS团队协作规范
    百度前端学院-基础学院-第四课
    百度前端学院-基础学院-第三课
    百度前端学院-基础学院-第二课
    vue(三)-父子组件通信
    setTimeout()与clearTimeout()
    vue(二)-父子组件语法
    vue(一)使用vue-cli搭建项目
    CSS table-layout 属性
    git学习
  • 原文地址:https://www.cnblogs.com/qihuan/p/5025568.html
Copyright © 2011-2022 走看看