一、造成表單重複提交的原因
1.服務器處理時間過長,當再次點擊提交時,導致服務器接收到兩條或者多條相同信息;
2.forward跳轉引起重複提交,頁面跳轉主要有兩種情況:一是,請求轉發,主要指服務端進行跳轉,瀏覽器地址不會發生改變;二是,重定向,在客戶端進行跳轉,瀏覽器中地址發生改變。
二、使用token令牌攔截防止表單重複提交
1.token工作原理:
1)用戶首次訪問包含表單的頁面時,服務器會在這次會話中創建session對象,產生令牌值,同時保存的session對象中,然後將這個令牌值與表單一起提交服務器;
2)當用戶提交時,服務器判斷請求參數中的令牌值和session中保存的令牌值是否相等,相等,則清除session中的令牌值,不相等,則提示用戶,同時則產生一個新的令牌值,保存到session中,當用戶重新訪問提交頁面時,將新的令牌值作爲隱藏輸入域的值。
三、實例
1.index.jsp
<s:form action="emp_add.action" method="post">
<table align="center">
<tr>
<td colspan="2"><label>添加用戶</label></td>
</tr>
<s:textfield name="user.PId" label="部門"></s:textfield>
<s:textfield name="user.TName" label="姓名"></s:textfield>
<s:radio name="user.TSex" list="#{1:'男',0:'女'}" value="1" label="性別"></s:radio>
<s:textfield name="user.TUsername" label="賬號"></s:textfield>
<s:textfield name="user.TPassword" label="密碼"></s:textfield>
<!-- <s:textfield name="user.setTRegtime" label="註冊時間"></s:textfield> -->
<tr>
<td colspan="2">
<button>添加</button>
<a href="${pageContext.request.contextPath}/employee/allpage.jsp">返回</a>
</td>
</tr>
<s:token/><!-- 添加令牌token -->
</table>
</s:form>
2.employeeAction.java
public class employeeAciton extends ActionSupport {
public employeeServer empdao = new employeeServer();
TUser user;
public TUser getUser() {
return user;
}
public void setUser(TUser user) {
this.user = user;
}
public String add() {
empdao.adduser(user);
return this.find();
}
}
3.employee.java
<struts>
<package name="employee" extends="struts-default">
<action name="emp_*" class="com.casv.action.employeeAciton" method="{1}">
<!-- token攔截器,防止表單重複提交 -->
<interceptor-ref name="token">
<!-- 指定攔截的方法add() -->
<param name="includeMethods">add</param>
</interceptor-ref>
<interceptor-ref name="defaultStack" />
<!-- 若重複提交數據,則返回到allpage.jsp頁面中 -->
<result name="invalid.token">/employee/allpage.jsp</result>
<result name="alluserPage">/employee/allpage.jsp</result>
</action>
</package>
</struts>