struts 1によるフォームの重複コミットの防止

2284 ワード

1、まずフォームを要求する前に:this.saveToken(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>