最近公司上线,有同志进行攻击,表当防重复提交也没有弄,交给我 ,本人以前也没弄过,知道大概的思路,但是那样实在是太麻烦了,虽然后面试过使用过滤器加拦截器实现,不过还是有点小麻烦。

后来在网上搜索后发现不错的方案如下:注解加拦截器完成

首先创建注解token:

@Target(ElementType.METHOD)//设置注解的可用范围-这里是方法上
@Retention(RetentionPolicy.RUNTIME)//设置注解的作用范围
public @interface Token { boolean save() default false; boolean remove() default false;
}

创建token拦截器:

 public class TokenInterceptor extends HandlerInterceptorAdapter {

   @Override
  public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
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;
  }
}

然后在配置文件中配置好拦截器:注意这种方式在配置注解的处理器的时候需要配置:请求映射的方法处理器以及请求映射处理的适配器,如果使用

 <bean
class="org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping" />这个默认的会找不到方法处理器    <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping">
  <property name="interceptors">
    <list>
      <bean class="com.rbao.east.interceptor.TokenInterceptor"/>
    </list>
  </property>
</bean>
<bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter"/>

然后在需要生成token的方法上面添加@Token(save = true)

需要进行校验的方法上添加@Token(remove = true)

最后在显示页面上添加隐藏字段:

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

本文来自:

http://blog.icoolxue.com/submitted-by-spring-mvc-to-prevent-data-duplication/

以及

http://chenzhou123520.iteye.com/blog/1702563

结合

Spring太'激情'了.有好的文章希望能推荐推荐

如果有什么好的方案,希望各位朋友推荐推荐相互学习,多谢~~~

最新文章

  1. elasticsearch5.0及head插件安装
  2. 读书笔记——Windows核心编程(2)禁止C运行时触发的所有Debug Assertion Failed对话框
  3. [转]几个开源的.net界面控件
  4. Linux中kettle自动化部署脚本
  5. EM算法--第一篇
  6. C#抽象方法与抽象实例--C#基础
  7. [NOIp 2017]逛公园
  8. sql语句可以截取指定字段后面的字符串
  9. mongodb 3.2 分片 + 副本集
  10. 在IIS7里配置 ISAPI,运行dll程序,总提示下载dll
  11. Window下部署Maven Nexus
  12. Shader-另类实现
  13. swift - 闭包 -定义和使用
  14. zoj Beautiful Number(打表)
  15. Python 入门基础9 --函数基础2 实参与形参
  16. bodgeit测试平台
  17. 解决jenkins下使用HTML Publisher插件后查看html报告显示不正常
  18. 解决Android adjustresize全屏无效问题
  19. 诺贝斯特(厦门)电气有限公司http://www.thebest.cn.com/
  20. 基于pyteseract google ocr的图形验证码识别

热门文章

  1. RPG游戏中如何判断敌人是否在玩家的攻击范围之内
  2. You Don&#39;t Know JS: Scope &amp; Closures (第2章: Lexical Scope)
  3. 小程序动态添加class及调接口传递多个参数
  4. Linux 权限管理命令
  5. Leetcode 692 - Note
  6. UI基础一:简单的BOL查询
  7. 559. Maximum Depth of N-ary Tree C++N叉树的最大深度
  8. Beta阶段——第5篇 Scrum 冲刺博客
  9. mybatis*中DefaultVFS的logger乱码问题
  10. Hive QL的实例