本文实例为大家分享了spring mvc如何防止数据重复提交,供大家参考,具体内容如下
方法分析:
这里使用的防止数据重复提交的方法是使用token,给所有的url加一个拦截器,在拦截器里面用java的uuid生成一个随机的uuid并把这个uuid放到session里面,然后在浏览器做数据提交的时候将此uuid提交到服务器。服务器在接收到此uuid后,检查一下该uuid是否已经被提交,如果已经被提交,则不让逻辑继续执行下去。
源码实现:
注解token代码:
1
2
3
4
5
6
|
@target (elementtype.method) @retention (retentionpolicy.runtime) public @interface token { boolean save() default false ; boolean remove() default false ; } |
拦截器tokeninterceptor代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
|
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 ; } } |
spring mvc的配置文件:
1
2
3
4
5
6
7
8
|
<!-- 拦截器配置 --> <mvc:interceptors> <!-- 配置token拦截器,防止用户重复提交数据 --> <mvc:interceptor> <mvc:mapping path= "/**" /> <bean class = "com.storezhang.web.spring.tokeninterceptor" /> </mvc:interceptor> </mvc:interceptors> |
使用方法:
1、在需要生成token的controller上增加@token(save=true);
2、而在需要检查重复提交的controller上添加@token(remove=true)就可以了。
另外,你需要在view里在form里增加下面代码:
1
|
<input type= "hidden" name= "token" value= "${token}" /> |
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:http://blog.icoolxue.com/submitted-by-spring-mvc-to-prevent-data-duplication/