1. web通过拦截器解决
1. session+token的方式
当表单加载时候,前端向服务器申请一个token,同时,服务器将token放在session中。
当提交表单时候,参数中带着token,服务器校验token,如果相同则放行,同时清除session。如果不同,则说明重复提交。
需要注意的是,如果请求返回了,或者刷新了表单等一些操作,需要重置token
如果页面有多个表单,那只能维护多个token....
2. 只过滤部门请求
可以在拦截器里面获取到此请求对应的controller,然后根据条件删选,比如注解,具体代码
// before the actual handler will be executed
27 public boolean preHandle(HttpServletRequest request,
28 HttpServletResponse response, Object handler) throws Exception {
29 long startTime = System.currentTimeMillis();
30 request.setAttribute("startTime", startTime);
31 if (handler instanceof HandlerMethod) {
32 StringBuilder sb = new StringBuilder(1000);
33
34 sb.append("-----------------------").append(SimpleDateFormatCache.getYmdhms().format(new Date()))
35 .append("-------------------------------------\n");
36 HandlerMethod h = (HandlerMethod) handler;
37 sb.append("Controller: ").append(h.getBean().getClass().getName()).append("\n");
38 sb.append("Method : ").append(h.getMethod().getName()).append("\n");
39 sb.append("Params : ").append(getParamString(request.getParameterMap())).append("\n");
40 sb.append("URI : ").append(request.getRequestURI()).append("\n");
41 System.out.println(sb.toString());
42 }
43 return true;
44 }
2. js端
1. 加标识
当提交之后,将标识只为一种状态,当再次提交时,判断状态。
2. 禁用按钮
提交之后,禁用提交按钮。
需要注意的是,当请求返回之后,需要重置按钮或者状态,否则影响下次使用。