struts2数据校验与国际化

时间:2023-03-08 17:41:09
struts2数据校验与国际化

数据校验:

Action里的validate()方法能校验action类所有的方法,如果有错,如:addFieldError,会自动返回到workflow校验拦截器不向下继续进行,不用return input(如果在别的action校验的话,需要手动return input)。如果我们只希望校验其中一个方法的话,把validate()方法改为validate+方法名(“首字母大写”);就只校验其中一个的方法。

我的Action:

package cn.jnit.action;

import org.apache.commons.lang.StringUtils;

import cn.jnit.bean.User;

import com.opensymphony.xwork2.ActionSupport;

public class RegisterAction extends ActionSupport {

private static final long serialVersionUID = 1L;

private User user;

public String login() throws Exception {

return SUCCESS;

}

public String login1() throws Exception {

return SUCCESS;

}

@Override

public void validate() {

if(StringUtils.isEmpty(user.getName()))

addFieldError("user.name", "用户名不能为空");

if(StringUtils.isEmpty(user.getPwd()))

addFieldError("user.pwd", "密码不能为空");

}

public User getUser() {

return user;

}

public void setUser(User user) {

this.user = user;

}

}

Strut2验证框架:

验证文件的编写:

在action包下,创建一个action类名-validation.xml的文件,如我的

RegisterAction-validation.xml:

<?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE validators PUBLIC

"-//OpenSymphony Group//XWork Validator 1.0.3//EN"

"http://www.opensymphony.com/xwork/xwork-validator-1.0.3.dtd">

<validators>

<field name="user.name">

<field-validator type="requiredstring">

<message>用户名不能为空</message>

</field-validator>

<field-validator type="stringlength">

<param name="minLength">5</param>

<param name="maxLength">10</param>

<message>用户名长度在5--10位之间</message>

</field-validator>

</field>

</validators>

其中验证类型,<field-validator type="">其中的type有很多类型,可以在

xwork-core-2.2.1.jar→com.opensymphony.xwork2→validator→validators→default.xml里有:

<?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE validators PUBLIC

"-//OpenSymphony Group//XWork Validator Config 1.0//EN"

"http://www.opensymphony.com/xwork/xwork-validator-config-1.0.dtd">

<!-- START SNIPPET: validators-default -->

<validators>

<validator name="required" class="com.opensymphony.xwork2.validator.validators.RequiredFieldValidator"/>

<validator name="requiredstring" class="com.opensymphony.xwork2.validator.validators.RequiredStringValidator"/>

<validator name="int" class="com.opensymphony.xwork2.validator.validators.IntRangeFieldValidator"/>

<validator name="long" class="com.opensymphony.xwork2.validator.validators.LongRangeFieldValidator"/>

<validator name="short" class="com.opensymphony.xwork2.validator.validators.ShortRangeFieldValidator"/>

<validator name="double" class="com.opensymphony.xwork2.validator.validators.DoubleRangeFieldValidator"/>

<validator name="date" class="com.opensymphony.xwork2.validator.validators.DateRangeFieldValidator"/>

<validator name="expression" class="com.opensymphony.xwork2.validator.validators.ExpressionValidator"/>

<validator name="fieldexpression" class="com.opensymphony.xwork2.validator.validators.FieldExpressionValidator"/>

<validator name="email" class="com.opensymphony.xwork2.validator.validators.EmailValidator"/>

<validator name="url" class="com.opensymphony.xwork2.validator.validators.URLValidator"/>

<validator name="visitor" class="com.opensymphony.xwork2.validator.validators.VisitorFieldValidator"/>

<validator name="conversion" class="com.opensymphony.xwork2.validator.validators.ConversionErrorFieldValidator"/>

<validator name="stringlength" class="com.opensymphony.xwork2.validator.validators.StringLengthFieldValidator"/>

<validator name="regex" class="com.opensymphony.xwork2.validator.validators.RegexFieldValidator"/>

<validator name="conditionalvisitor" class="com.opensymphony.xwork2.validator.validators.ConditionalVisitorFieldValidator"/>

</validators>

<!--  END SNIPPET: validators-default -->

可以选择。

如果只想验证其中一个方法,那么可以在action下创建:ActionName-struts2.xml里的action标签 name属性值-validation.xml,如我的

RegisterAction-userreg-validation.xml,struts2数据校验与国际化

实现国际化:

国际化(Internationalization:I18N):

常用的ISO-639语言代码有zh(汉语)、en(英语)、fr(法语)、de(德语)均由两个小写字母组成

常用的ISO-3166标准的国家和地区码有CN(*)、US(美国)、GB(英国)、TW(*)、HK(香港)等,均由两个大写字母组成。

全局变量的国际化:

首先要在Struts.xml里加入:

<constant name="struts.custom.i18n.resources" value="message"></constant>

在src下创建:

Message_language_country.properties,

如我的:

message_en_US.properties里的值:welcome=welcome to China;

message_zh_CN.properties里的值:welcome=欢迎来到中国;

然后在JSP页面里:

<s:text name="getText('welcome')"></s:text>就可以输出,可以根据浏览器语言的配置来配置自己的国际化properties。

Action范围的国际化:那么需要在Action类下面创建:

Action类名_language_country.properties,

如我的:

struts2数据校验与国际化

我的RegisterAction_en_US.properties值为:

user.name=name

user.pwd=pwd

user.age=age

我的RegisterAction_zh_CN.properties值为:

user.name=用户名

user.pwd=密码

user.age=年龄

这里面的user是和我RegisterAction类里的User属性相对应的,

然后我的上传表单为:

<body>

<s:form action="register"  method="post">

<s:textfield name="user.name" label="%{getText('user.name')}"></s:textfield>

<s:password name="user.pwd" label="%{getText('user.pwd')}"></s:password>

<s:textfield name="user.age" label="%{getText('user.age')}"></s:textfield>

<s:submit value="登录"></s:submit>

</s:form>

</body>

上传表单的label名就会根据自己浏览器使用的语言查找对应的语言properties来显示不同的语言,另外这个表单只有在经过Action跳转到表单页面的时候才会显示出数据,因为properties现在是Action范围的文件,没有经过Action跳转到表单JSP就不会显示对应的label数据。

资源文件范围还有包范围资源文件,明明方法是在对应包下添加package_language_country.properties资源文件,其中package为固定写法,只有处于该包及子包下的Action才可以访问该文件。