struts 1によるフォームの重複コミットの防止
2284 ワード
1、まずフォームを要求する前に:this.saveToken(request);
2、次のフォーム使用:ラベル
3、さらに処理フォームでisTokenValid(request)でtokenを検査し、合法的にresetToken(request)する.
2、次のフォーム使用:
3、さらに処理フォームでisTokenValid(request)でtokenを検査し、合法的にresetToken(request)する.
<html:form action="/Login.do?m=doLogin" method = "POST">
<html:text property="username"></html:text>
<html:submit>Submit</html:submit>
</html:form>
package com.tim.beans;
import org.apache.struts.action.ActionForm;
public class UserInfo extends ActionForm{
private static final long serialVersionUID = 6705948863335091123L;
private String username;
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
}
public ActionForward Login(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response){
this.saveToken(request);
return mapping.findForward("login");
}
public ActionForward doLogin(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response){
ActionMessages errors = new ActionMessages();
if(!isTokenValid(request)){
errors.add(ActionMessages.GLOBAL_MESSAGE,new ActionMessage(" !",false));
}
if(!errors.isEmpty()){
saveErrors(request,errors);
return mapping.findForward("info");
}
resetToken(request);
System.out.println(" !");
return mapping.findForward("info");
}
<form-beans>
<form-bean name="userInfo" type="com.tim.beans.UserInfo">
<form-property name="username" type="java.lang.String"></form-property>
</form-bean>
</form-beans>
<load-on-startup>0</load-on-startup>