本文實例為大家分享了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/