这里通过Struts2的UI验证数据。
首先引入**<s:head />标签**,该标签会自动生成Struts2标签需要的JS和CSS文件的引入标签。这样就可以使用Struts2中提供的验证了。
使用了Struts2的表单之后并不需要使用任何的HTM中的table标签,因为Struts2会自动生成需要的tables。
1、下面是JSP页面的编写:
我们这样配置struts.xml文件:
当我们点击Login按钮时,请求就转到LoginAction。
这里的defalut包我们继承了struts-default,而这个struts-default包中包含了一系列的定义在defaultstack中的拦截器。这个struts-default包定义在struts-default.xml文件中。
一些最常用的拦截器就放在struts-default package中的defaultstack里面。
2、Action的编写:
我们的LoginAction继承了ActionSupport,使得他很好的继承了ActionSupport中对于一些common tasks(common tasks分配在各个拦截器中)的默认实现。
接下来是编写LoginAction:
public class LoginAction extends ActionSupport{
private String username;
private String password;
public LoginAction(){}
public String execute(){
return SUCCESS;
}
public void validate(){
if(getUsername().length() == 0){
addFieldError("username", "User Name error");
}
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
}
注意这里有一个validate()和addFieldError()方法;上面也讲到了实现了ActionSupport之后便会继承那些默认拦截器的默认实现。而这个validate()方法是workflow拦截器中的一个方法。workflow拦截器会判断action是否实现了Validateable接口。如果实现了,workflow拦截器就会调用validate()方法。validate()方法并没有返回任何错误,而是通过ValidationAware接口把错误信息存储起来。而addFieldError()方法也是workflow拦截器中的一个方法。