1.验证
- public class ProductAction extends ActionSupport
- public String execute() throws Exception
- System.out.println("execute");
- return SUCCESS;
- }
- public String add() {
- return SUCCESS;
- }
- public String del() {
- return SUCCESS;
- }
- public void validate() {
- System.out.println("我是Validate方法");
- }
- }
- /*
- 实际运行起来,我们会发现,无论你执行任何方法,该validate方法都会被执行,显然这不是我们想要的,当然struts肯定也想到这个问题了,所以它提出了一个约定,你可以自己编写针对某个方法的validate,从而达到自己的验证目的,关于这个约定问题,也就是我们经常说的"约定大于配置"。
- */
2>编写自己的validate方法
- //如何编写自己需要的验证方法呢?实际上很简单,你只需写一个返回类型为void,方法名子
- //为 validate*();*为你需要验证的方法名的首字母大写名称。
- //例如你想验证上面的del()方法,你只需这样写即可:
- public void validateDel() {
- //验证代码...
- }
- //此种写法底层是由反射机制来实现的,需要注意的是,必须要按此约定来进行编写,还是那
- //句话,约定大于配置。
3>执行流程:
- /*
- 加了验证方法以后,程序的流程将是这个样子的:
- 1) 首先进行类型转换
- 2) 然后进行输入校验(validate)
- 3) 当在Action 中指定了自定义的execute 方法时,首先会执行自定义的execute 方法所对 应的输入校验方法,然后再去执行validate 方法。
- 4) 如果在上述过程中不管出现了任何错误都将不会再去执行自定义的execute方法,流程将会直接转向struts.xml中该action中的name属性值为input的result所对应的页面。
- */
4>添加错误提示
- //ActionSupport这个类提供了添加错误提示消息的方法
- 1. addActionError("xxxx");
- 2. addFieldError("k","v");//键值对的添加方式
- 3. addActionMessage();//注意此方法只会添加信息,不会阻止程序的正常执行流程!
- /*
- 1. 想在页面获取错误提示消息可以使用struts标签<s:actionerror/>和<s:fielderror/>
- 2. 必须是通过请求转发的方式到达此页面方可拿到值,因为struts默认是把值放到request空间里面的。
- 3. Action级别的错误信息列表对开发者来说是只读的!!!(要特别注意此句话)
- 4. struts默认给添加的Field 级别的错误提示消息是可以自定义的。
- 1) 新 建一个以 xxxAction 名命名的 properties文件,如ProductAction.properties。
- 2) 然后在该属性文件中指定每一个出错字段的错误消息,例如invalid.fieldvalue.prodName=prodName invalid!!
- */
validation.xml 的命名规则和放置路径:
文件名:<ActionClassName>-validation.xml
<ActionClassName>就是要验证的Action类的名字。要将此文件放于Class文件相同的目录。
如果在Action类在struts配置中有多个action实例(action name),那么对应某个action的验证文件名规则如下:
文件名:<ActionClassName>-<aliasName>-validation.xml
例如:UserAction-login-validation.xml
(注意:上面的<aliasName>并不是method name,而是struts.xml中配置的action的name)
例:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE validators PUBLIC "-//OpenSymphony Group//XWork Validator 1.0.2//EN"
"http://www.opensymphony.com/xwork/xwork-validator-1.0.2.dtd">
<validators>
<field name="username">
<field-validator type="requiredstring">
<param name="trim">true</param>
<message>请填写用户名</message>
</field-validator>
<field-validator type="stringlength">
<param name="minLength">4</param>
<param name="maxLength">32</param>
<message>用户名长度应在4到32个字符间</message>
</field-validator>
</field>
<field name="password">
<field-validator type="requiredstring">
<message>请填写密码</message>
</field-validator>
<field-validator type="stringlength">
<param name="minLength">6</param>
<param name="maxLength">32</param>
<message>为了您账号的安全,请设置6个字母以上的密码(最长可设置32个字母)</message>
</field-validator>
</field>
</validators>
- /*
- 有时候,我们会用到struts校验框架(有效的xml),具体来说分为字段优先校验器与校验器 优先校验器。当有校验器出现的时候,校验的执行顺序将是:
- 1) 首先执行校验框架(xml 文件)
- 2) 执行自定义方法的校验方法(validateMyExecute)
- 3) 执行validate 方法
- */
2.国际化
- //对于国际化的资源文件,其命名规则是:package_语言名_国家名,比如package_zh_CN,package_en_US