對于login方法的校驗,可以通過<ActionClassName>-<ActionAliasName>-validation.xml文件來校驗,即RegistAction-login-validation.xml文件進行校驗。同時,RegistAction-validation.xml的校驗規(guī)則仍舊對login方法有效。即login方法的校驗規(guī)則是Region-validation.xml和RegistAction-login-validation.xml的總和。
如果RegistAction繼承了BaseAction,那么對于BaseAction類的校驗規(guī)則也會被RegistAction類所繼承校驗。具體來說,其校驗規(guī)則的搜索文件規(guī)則如下:
BaseAction-validation.xml
BaseAction-別名-validation.xml
RegistAction-validation.xml
RegistAction-別名-validation.xml
對于Struts2所支持的內(nèi)建校驗器,我們可以通過xwork.2.1.2.jar中的com/opensymphony/xwork2/validator/validators/default.xml文件查看。
除了配置文件,Struts2也支持Annotation。下面就是使用Annotation配置的RegistAction:
@Validation()
public class RegistAction extends ActionSupport {
private static final long serialVersionUID = -2113900523366315993L;
//該請求包含的4個請求參數(shù)
private String name;
private String pass;
private int age;
private Date birth;
public String getName() {
return name;
}
@RequiredStringValidator(type=ValidatorType.FIELD,key="name.required",message="")
@RegexFieldValidator(type=ValidatorType.FIELD,expression="\\w{4,25}",key="name.regex",message="")
public void setName(String name) {
this.name = name;
}
public String getPass() {
return pass;
}
@RequiredStringValidator(type=ValidatorType.FIELD,key="pass.required",message="")
@RegexFieldValidator(type=ValidatorType.FIELD,expression="\\w{4,25}",key="pass.regex",message="")
public void setPass(String pass) {
this.pass = pass;
}
public int getAge() {
return age;
}
@IntRangeFieldValidator(message="",key="age.range",min="1",max="150")
public void setAge(int age) {
this.age = age;
}
public Date getBirth() {
return birth;
}
@DateRangeFieldValidator(message="",key="birth.range",min="1900/01/01",max="2050/01/21")
public void setBirth(Date birth) {
this.birth = birth;
}
}

對于不能通過內(nèi)置校驗器進行校驗的邏輯,則可通過重寫validate()方法來實現(xiàn)。如果一個Action中存在多個邏輯處理,則需要通過validateXxx()方法來分別進行校驗,其中Xxx代表方法名。如login()方法對應(yīng)的校驗方法為validateLogin()。
Struts2的輸入校驗流程:
1。類型轉(zhuǎn)換器負(fù)責(zé)對字符串的請求參數(shù)執(zhí)行類型轉(zhuǎn)換,并將這些值設(shè)置成Action的屬性值。
2。在執(zhí)行類型轉(zhuǎn)換過程中,如果發(fā)生異常,則將異常保存到ActionContext中,并由conversionError攔截器負(fù)責(zé)將其封裝到fieldError里。然后執(zhí)行第3步;如無異常,直接執(zhí)行第3步。
3。調(diào)用Struts2內(nèi)置的輸入校驗規(guī)則進行輸入校驗
4。通過放射調(diào)用validateXxx()方法。
5。調(diào)用validate()方法。
6。如果上述都未發(fā)生fieldError,將調(diào)用Action里處理用戶請求的處理方法;如果出現(xiàn)了fieldError,則轉(zhuǎn)入input邏輯視圖所指定的視圖資源。