Struts2国际化和数据验证

来源:互联网 发布:杀女婴知乎 编辑:程序博客网 时间:2024/05/20 00:14

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;@Overridepublic String execute() throws Exception {return SUCCESS;}//加入此注册可以跳过验证@SkipValidationpublic 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=usernameuser.password=passworduser.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><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=usernameuser.password=passworduser.login=login
package_zh_CN.properties的文件内容
login.title=\u6B22\u8FCE\u8FDB\u5165\u5E10\u53F7\u767B\u5F55\u7CFB\u7EDF(\u5305)user.username=\u7528\u6237\u540D\u79F0user.password=\u9752\u586B\u5199\u5BC6\u7801user.login=\u767B\u5F55\u6211\u7684\u5E10\u53F7abc=\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\uFF01user.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注解,跳过指定方法的验证
在某个方法上面加上该注解后,该方法将跳过验证
@SkipValidationpublic String login() throws Exception{//对该login方法跳过验证return "login";}

验证
input 是验证失败后要跳转的界面