Struts2笔记 - 简单数据验证

这里通过Struts2的UI验证数据。

首先引入<s:head />标签,该标签会自动生成Struts2标签需要的JS和CSS文件的引入标签。这样就可以使用Struts2中提供的验证了。

使用了Struts2的表单之后并不需要使用任何的HTM中的table标签,因为Struts2会自动生成需要的tables。

1、下面是JSP页面的编写:

Insert title here
<s:head />


<s:form action=”LoginAction “>
<s:textfield name=”username” lable=”Username” />
<s:password name=”password” lable=”Password” />
<s:submit value=”Login” />
</s:form>

我们这样配置struts.xml文件:




/HelloWorld.jsp


当我们点击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拦截器中的一个方法。

arthinking wechat
欢迎关注itzhai公众号