struts2验证规则validation配置文件命名方式总结
1、Action级别校验命名格式:
ActionClassName-validation.xml |
2、Action中某个方法的校验命名格式:
ActionClassName-ActionAliasName-validation.xml |
注意:这里的ActionAliasName(action别名)指的是struts.xml中Action name="XX"的xx的名称,而不是method="XX"的名称。
3、如果以上2个校验文件都存在,那么2个文件都会被执行;如果2个校验文件中的校验属性相同那么将被执行同校验属性中ActionClassName-ActionAliasName-validation.xml中的校验规则。
4、在使用visitor校验器的时候,<message>out</message>必须要配置且out消息必须得写,否则会报空指针错误。
5、visitor校验器配置方法,这里不详细列举。仅说明其用途:如果几个Action同时用到一个模型类,都要验证这个模型类中的某个属性。那么只需要配置这个模型类的验证文件,然后以visitor校验器的方式在Action的验证文件中引用模型类的验证文件名即可。
例如:模型类的验证文件名叫:User-userContext-validation.xml,Action的验证文件名件中引用如下:
<field name="user"> <field-validator type="visitor"> <param name="context">userContext</param> <param name="appendPrefix">true</param> <message>out</message> </field-validator> </field> |
6、采用非字段校验器配置格式, 配置示例:
<validators> <!--使用非字段校验器风格;来配置字段表达式校验器--> <validator type="fieldexpression"> <!--指定校验字段pass--> <param name="fieldName">pass</param> <!--指定逻辑表达式--> <param name="expression"><![CDATA[(pass == rpass)]]</param> <!--指定校验失败的提示信息--> <message>两个密码必须相同!</message> </validator> </validators> |
7、采用字段校验器配置格式, 配置示例:
<validators> <!--使用字段校验器格式来配置字段表达式校验器,校验pass属性--> <field name="pass"> <field-validator type="fieldexpression"> <!--指定逻辑表达式--> <param name="expression"><![CDATA[(pass == rpass)]]</param> <!--指定校验失败的提示信息--> <message>两个密码必须相同!</message> </field-validator> </field> </validators> |
梦想,是一个目标,是让自己活下去的原动力,是让自己开心的原因。坚持!