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=loginmsg_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=loginpackage_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\uFF01UserAction_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 是验证失败后要跳转的界面
相关文章推荐
- Struts2教程4:使用validate方法验证数据
- struts2 在Action简单数据验证,取得request,session,application,
- 框架 day28 Struts2-封装数据,类型转换,数据校验,国际化,拦截器
- Struts2【UI标签、数据回显、资源国际化】
- Struts2教程5:使用Validation框架验证数据
- Struts2:使用Validation框架验证数据
- struts2 使用Validation框架验证数据
- struts2表单验证及国际化实现
- struts2简单验证 与 Acton向jsp传递数据的途径
- Struts2教程4:使用validate方法验证数据
- struts2之数据验证
- Struts2_11_简单数据验证
- 数据验证,数据转换器,国际化
- Struts2:使用validate方法验证数据
- Struts2数据验证机制
- struts2--(3)--一些小的知识---简单数据验证信息回显问题
- Struts2自定义类型转换器、自定义拦截器和用户输入数据的验证
- Struts2教程4:使用validate方法验证数据
- Struts2教程4:使用validate方法验证数据