您的位置:首页 > 编程语言 > Java开发

Struts2国际化和数据验证

2017-07-25 12:24 169 查看

Struts2国际化

Action类

package com.mingde.action;

import org.apache.struts2.interceptor.validation.SkipValidation;

import com.opensymphony.xwork2.ActionSupport;

@SuppressWarnings("serial")
public class HelloAction extends ActionSupport{

private String username;
private String password;

@Override
public String execute() throws Exception {
return SUCCESS;
}
//加入此注册可以跳过验证
@SkipValidation
public String login() throws Exception {
return "input";
}

public void validate() {
if(null==username || "".equals(username) || null==password || "".equals(password) ){
this.addFieldError("error", getText("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;
}

}


全局国际化

第一步:创建全局国际化文件

可在任何包中定义全局国际化文件:
msg_en_US.properties
//en_US代表英文状态
msg_zh_CN.properties
//zh_CN代表中文状态
注意:en,zh代表语言代码,而US,CN代表国家代码

第二步:定义文件内容

msg_en_US.properties文件内容
login.title=WelCome!
user.username=username
user.password=password
user.login=login
msg_en_US.properties文件内容
//在properties文件中,中文会被自动编码

login.title=\u6B22\u8FCE\u754C\u9762\uFF01  //欢迎界面
user.username=\u7528\u6237\u540D	//用户名
user.password=\u5BC6\u7801		//密码
user.login=\u767B\u5F55			//登录

第三步:在struts.xml文件中配置全局资源文件

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.3//EN"
"http://struts.apache.org/dtds/struts-2.3.dtd">
<struts>
<constant name="struts.enable.DynamicMethodInvocation" value="true"></constant>
<constant name="struts.devMode" value="true"></constant>
<constant name="struts.i18n.reload" value="true"></constant><!-- 自动对国际化刷新 -->
<!-- 引用全局国际化的文件位置 ,打开国际化-->
<constant name="struts.custom.i18n.resources" value="com.mingde.resources.msg"></constant>
<package name="struts_gjh" extends="struts-default">
<action name="hello" class="com.mingde.action.HelloAction">
<interceptor-ref name="defaultStack">
<param name="validation">login</param><!-- 排除验证方法 -->
<param name="workflow">execute</param><!-- 指定验证方法 -->
</interceptor-ref>
<result>welCome.jsp</result>
<result name="input">login.jsp</result>
</action>
</package>
</struts>

第四步:定义JSP页面显示登录

<body>
<s:a href="hello?request_locale=zh_CN">中文</s:a>
<s:a href="hello?request_locale=en_US">English</s:a>
4000
<h2><s:text name="login.title"></s:text></h2>
<s:fielderror></s:fielderror>
<s:form action="hello">
<s:textfield name="abc" label="%{getText('abc')}"></s:textfield>
<s:textfield name="username" label="%{getText('user.username')}"></s:textfield>
<s:password name="password" label="%{getText('user.password')}"></s:password>
<s:submit value="%{getText('user.login')}"></s:submit>
</s:form>
</body>

包级别国际化

包级别国际化只能定义在Action包里或父包,并且包名开头只能以package开头
如:package_en_US.properties ; package_zh_CN.properties
包级别国际化不需要在struts.xml配置,可以直接使用

package_en_US.properties的文件内容
login.title=Hello!WelCome!(bao)
user.username=username
user.password=password
user.login=login
package_zh_CN.properties的文件内容
login.title=\u6B22\u8FCE\u8FDB\u5165\u5E10\u53F7\u767B\u5F55\u7CFB\u7EDF(\u5305)
user.username=\u7528\u6237\u540D\u79F0
user.password=\u9752\u586B\u5199\u5BC6\u7801
user.login=\u767B\u5F55\u6211\u7684\u5E10\u53F7
abc=\u7EA2\u53D1


Jsp页面
<body>
<a href="hello?request_locale=zh_CN">中文</a>
<a href="hello?reqeust_locale=en_US">Englist</a>
<h2><s:text name="login.title"></s:text></h2>
<s:form action="hello!login">
<s:textfield name="user.username" label="%{getText('user.username')}"></s:textfield>
<s:password name="user.password" label="%{getText('user.password')}"></s:password>
<s:submit value="%{getText('user.login')}"></s:submit>
</s:form>
</body>

Action级别的国际化

注意:Action级别>包级别>全局级别

Action级别的国际化文件名与用到该文件的Action类的名字一样;
如:HelloAction.java
文件名:HelloAction_en_US.properties   HelloAction_zh_CN.properties
Action类也不需要在struts.xml配置,可以直接使用

使用Struts2国际化注意项

1.使用国际化时,或要切换语言,则必须进入struts.xml和Action类通过两者再返回页面,

才能实现切换语言成功

2.在国际化语言中(msg_en_US.properties)自定义属性和值(键=值),

如:login.title=WelCome!

若用到其键的则直接用struts2中的方法:如

<s:text name="login.title"></s:text>

3.如果有定义多个国际化的话(如:全局,包,Action),那么当你想切换国际化语言时,会先从Action里面查找,如果有就用在Action的国际化,如果没有就查包的,如果包也没有就查全局的;但第一次使用他会自动调用全局的显示

4.若中文国际化语言有对某个属性有赋值的话,而英文没有的话,那么当进入中文状态时,会将那段key的value取出来赋值,当英文状态时,因为英文的国际化没有设置所以,他的值会是key本身(也就是说key的值就是key的字段名)

5.若用包的国际化语言,那么包的国际化语言的命名只能是package_en_US.properties

6.若使用全局的国际化,则必须在struts.xml中定义

<constant name="struts.i18n.reload" value="true"></constant>

<constant name="struts.custom.i18n.resources" 

value="com.mingde.resources.msg(全局国际化的路径)"></constant>

后面的msg是指国际化的开头字符,如:msg_zh_CN.properties

7.如果定义的Action的国际化语言,那么国际化语言的开头名称必须是该Action的名称

如:Action:HelloAction.java

那么国际化语言:HelloAction_en_US.properties

数据验证

方法一:

在国际化中定义错误信息
UserAction_zh_CN.properties文件配置

user.username.error=\u5BF9\u4E0D\u8D77\uFF0C\u7528\u6237\u540D\u4E0D\u80FD\u4E3A\u7A7A\uFF01
user.password.error=\u5BF9\u4E0D\u8D77\uFF0C\u5BC6\u7801\u4E0D\u80FD\u4E3A\u7A7A\uFF01
UserAction_en_US.properties文件配置

user.username.error=sorry,username can't empty!

user.password.error=sorry,password can't empty!

Action类

/**
* validate()方法要验证此Action中的所有方法,如果使用validate+方法名()只
* 验证指定的方法,比如下面的validateExecute()只验证execute()方法
*/
//此方法只验证Execute方法

public void validateExecute() {
System.out.println("validateExecute.....");
if(null == user){
user = new User();
}
String username = user.getUsername();
String password = user.getPassword();
if(null == username || username.length() == 0){
this.addFieldError("username.error", getText("user.username.error"));
}
if(null == password || password.length() == 0){
this.addFieldError("password.error", getText("user.password.error"));
}
}
//此方法将对所有的方法进行验证
public void validate() {
System.out.println("validate.....");
if(null == user){
user = new User();
}
String username = user.getUsername();
String password = user.getPassword();
if(null == username || username.length() == 0){
this.addFieldError("user.username", getText("user.username.error"));
}
if(null == password || password.length() == 0){
this.addFieldError("user.password", getText("user.password.error"));
}
}


注意:在struts.xml中<result name="input">/login.jsp</result>是验证失败后要跳转的界面,一定要定义
JSP页面
<style>
<!-- 定义错误信息的字体颜色 -->
.errorMessage{
color:red;
}
</style>在body里面定义
<s:fielderror/>
<!-- 如果出错返回input,那么返回该界面后会自动显示错误信息 -->

方法二

原理:对validation和workflow两个拦截器使用execludeMethods排除指定方法
在Action定义validate()方法后再在struts.xml配置排除和包含验证指定方法
struts.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.3//EN"
"http://struts.apache.org/dtds/struts-2.3.dtd">
<struts>
<!-- 配置常量以覆盖default.properties文件的默认设置 -->
<constant name="struts.devMode" value="true"/>
<constant name="struts.enable.DynamicMethodInvocation" value="true"/>
<!-- 定义全局资源文件的路径 -->
<constant name="struts.custom.i18n.resources" value="com.minde.resources.msg"/>
<!-- 自动重新加载资源文件 -->
<constant name="struts.i18n.reload" value="true"/>
<package name="struts" extends="struts-default">
<action name="user" class="com.minde.action.UserAction">
<!-- 使用拦截器排除指定方法 -->
<!--下面两个关于验证的拦截器同时排除了对login方法的验证(第二种对指定方法的验证) -->
<interceptor-ref name="defaultStack">
<param name="validation.excludeMethods">login</param><!-- 排除指定方法 -->
<param name="workflow.excludeMethods">login</param> <!-- 对指定方法 进行验证-->
</interceptor-ref>
<result>/welcome.jsp</result>
<result name="input">/login.jsp</result>
<result name="login">/login.jsp</result>
</action>
</package>

</struts>

方法三

原理:使用@skipValiation注解,跳过指定方法的验证
在某个方法上面加上该注解后,该方法将跳过验证
@SkipValidation
public String login() throws Exception{		//对该login方法跳过验证
return "login";
}


验证

input 是验证失败后要跳转的界面
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: