struts2.0 验证

一、struts2.0的输入验证:
A、手动验证:
1)重写validate()
2)重写validateXxx()
B、使用验证框架
  Action类都要继承ActionSupport类

二、为一个Action设置多个逻辑处理:
 
为了更具有针对性的处理业务逻辑与针对性的进行输入校验,可以采用指定业务逻辑处理方法的方法,即对同一个Action设置多个逻辑处理方法,也就是说对于某个表单,我们可以指定在Action中让哪个方法来处理它的相关业务
 
解决方法:struts.xml中通过method属性指定处理其逻辑的方法
 
例如:
LoginAction中有login()和regester()两个业务处理方法:
<action name="login" class="com.oristnad.login.LoginAction" method="login">
<action name="reg" class="com.oristnad.login.LoginAction"   method="regist">
 

A、如果重写了ActionSupport的validate()方法,则该方法会校验所有的处理逻辑。
B、为了实现校验指定逻辑方法,可以在Action中增加一个validateXxx()方法,其中Xxx即是Action对应的处理逻辑方法。同时不重写validate方法
 
例如:
  validateRegist()方法---专门校验regist()方法,即校验reg表单提交的内容
  validateLogin()---专门校验login()方法,即校验login表单提交的内容
 
三、struts2的输入校验流程:
1)、类型转换器负责对字符串的请求参数执行类型装换,并将这些值设置为Action的属性值
2)、在类型转换过程中如果出现异常,则将异常信息保存到ActionContext中,conversionError拦截器负责将其封装到fieldError里,然后执行第3步;如果没有异常,则直接进入第3步
3)、如果有validateXxx()方法,则调用该方法
4)、调用Action类中的validate()方法
5)、如果经过上面4步都没有出现fieldError,将调用Action里处理用户请求的处理方法;
     如果出现了fieldError,将转入input逻辑视图所指定的视图资源。
       

四、struts2的验证框架初步:
        只需要为Action指定一个校验文件即可,该文件指定了Action的属性必须满足怎样的规则。
每个Action都有一个校验文件,命名规则:Action名字-validation.xml;
该文件保存在与该Action类的相同路径下。
1、配置文件:
<?xml version="1.0" encoding="GBK"?>
<!DOCTYPE validators PUBLIC "-//OpenSymphony Group//XWork Validator1.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>
      <field name="passwd">
         <field-validator type="requiredstring">
             <message key="error.password"></message>
         </field-validator>
     </field>
</validators>
 
 
1)<field name="username">--要验证的字段
2)<field-validator type="requiredstring">--验证规则(校验器)
3)<param name="trim">true</param>--校验参数
4)<message>用户名不能为空</message>--验证失败的输出信息

2、配置文件中使用国际化显示错误信息:
 
A、message元素的key属性:<message key="error.password"></message>
B、使用${getText("message-key")}: <message>${getText("error.username")}</message>

3、客户端验证:
  在<s:form>表单中添加validate="true"即可,struts2客户端验证仍是基于JavaScript的,struts2将服务器验证转为客户端验证。
  
<s:form action="login" validate="true">
   
 注意:
      A、如果验证文件中错误信息使用<message key="error.password"></message>形式输出的话,则页面会出现FreeMarker template error!的错误。
       故必须使用${getText("message-key")}形式
     
 B、不是所有的服务器端验证都可以转为客户端验证
 
4、校验器的配置风格:
 
1)字段校验器:字段优先
字段的校验遵循以下规则:
 
<validators>
	<field name="被校验的字段名">
 	   <field-validator type="校验器名">
 	       <param name="参数名">参数值</param>
 	       <message>校验失败的提示信息</message>
	</field-validator>
	</field>   
</validators>     
 
      
2)非字段校验器配置风格:校验器优先

 <validators>
  	 <validator type="校验器">
  	    <param name="fieldName">需要被校验的字段</param>
  	    <param name="参数">参数值</param>
  	    <message>校验失败的提示信息</message>
  	 </validator>
</validators>
 
 
5、常用的校验器:
required--必填校验器
requiredstring--必填字符串校验器
int--整数校验器
double--双精度校验器
date--日期校验器
expression--表达式校验器
email--电子邮件校验器
url--网址校验器
stringlength--字符串长度校验器
regex--正则表达式校验器

 
Struts2 验证框架不起作用的几种可能
1、命名是否符合约定:
<actionClass>-validation.xml 
<actionClass>-<actionAlias>-validation.xml
2.   validation.xml的标签是否正确。
3.   fieldName 命名是否和jsp以及 action中的属性一致
4.检查是否在同一个field里面配置了重复的参数,重复的参数也可能会使你的信息显示不出来
5、有可能是版本问题,今天用2.1.16的版本做了很久都不起作用,最后改成2.0.14版本,问题解决。
 

 

 

之所以转载这篇文章,是因为前一阵子,有个单位考我Struts2的验证,问到当error出现的时候,怎么写入ActionContext,其实人家的问题问的很深,我理解的是问Struts2框架验证怎么讲验证信息返回客户端,当时我是按照Servlet的write方法回答的,后来觉得没必要这么回答,只要简单的把其验证的流程说一下就好了!真问道实现机制……不会就不会了!

不过Validate()方法里面的this.addFieldError()方法要是能表述出来就更清晰了,当时我把这个方法名字给忘记了……  

你可能感兴趣的:(xml,框架,freemarker,正则表达式,struts)