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

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

  • 相关阅读:
    ArcGIS API ForJS 3.25开发总结(持续更新)
    geotools实现将shp导入mysql
    OL4如何以TMS服务调用WMTS服务的缓存切片
    PostGIS type: LINESTRING[2] We have a Multilinestring with 2 parts, can't use -S switch!解决方案
    OL4加载geowebcache 部署的离线切片
    geoserver发布自定义坐标系矢量切片(以北京54投影坐标系为例)
    geoserver使用sld(点通过svg填充)样式
    关于用geoserver进行切图自定义GridSet出现EPSG:2379: 0.0,0.0,-1.0,-1.0
    OL4通过ajax加载geoserver中WMS的GetFeatureInfo实现点击查询(解决跨域问题)
    作为一个GIS开发人员,你必须知道的坐标系那些事
  • 原文地址:https://www.cnblogs.com/qihuan/p/5025568.html
Copyright © 2011-2022 走看看