Struts2笔记 - 简单数据验证

发布于 2011-06-19 | 更新于 2020-09-20

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

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

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

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

Insert title here

我们这样配置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

本文链接: https://www.itzhai.comthe-struts2-notes-simple-data-validation.html

版权声明: 版权归作者所有,未经许可不得转载,侵权必究!联系作者请加公众号。

×
IT宅

关注公众号及时获取网站内容更新。