• 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}"     />

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

  • 相关阅读:
    用单循环链表实现约瑟夫问题。
    迅雷2014校园招聘笔试题
    JSP:JAVA Bean在JSP中的运用
    大学生学业指导类书目
    IOS详解TableView——对话聊天布局的实现
    jQuery EasyUI API 中文文档
    在Centos 5.4上安装Mysql5.5.10 (整理以前的工作文档)
    Centos环境下部署游戏服务器-SVN
    原本好好的程序,怎么电脑重启后就打不开了?
    UVA 10911 Forming Quiz Teams(dp + 集合最优配对问题)
  • 原文地址:https://www.cnblogs.com/qihuan/p/5025568.html
Copyright © 2020-2023  润新知