Struts数据效验
表单数据的验证:
前台验证:主要是通过JS验证, 表达数据是否合法!
后台验证:通过后台java代码进行验证!
Struts也提供了数据效验的方式!
Struts数据效验, 通过拦截器完成:
<interceptor
name="validation" class="org.apache.struts2.interceptor.validation.AnnotationValidationInterceptor"/>
* 注意:如果要想用struts的数据效验功能,必须继承ActionSupport或实现相关接口
1.代码方式验证
(1)代码方式验证Action中所有的方法:
public void validate() {
/**
* 输入需要验证的字段
*/
super.validate();
}
public void validateLogin() {
if(user.getName()==null||"".equals(user.getName())){
super.addFieldError("nameError", "用户名为空");
}
}
总结代码方式验证:
繁琐,设计很多重复的验证逻辑!例如:非空验证、数值验证、email、日期等。
Struts对于常用的验证,进行了封装,即提供了验证器, 验证指定的常用业务逻辑!
Struts提供的所有验证器:
路径:xwork-core-2.3.4.1.jar/com.opensymphony.xwork2.validator.validators/default.xml
如果写xml,从而定义验证规则:
XML文件名称语法: ActionClassName-validation.xml
注意:此xml需要与当期要验证的action在同一个目录:
举例:UserAction-validation.xml
xml文件:
<!DOCTYPE validators PUBLIC
"-//Apache Struts//XWork Validator 1.0.3//EN"
"http://struts.apache.org/dtds/xwork-validator-1.0.3.dtd">
<validators>
<!-- 需要验证的字段 -->
<field name="user.pwd">
<!-- 验证空 -->
<field-validator type="requiredstring">
<message>密码不能为空</message>
</field-validator>
<!-- 长度 -->
<field-validator type="stringlength">
<param name="minLength">6</param>
<param name="maxLength">8</param>
<message>密码为6-8位</message>
</field-validator>
</field>
(2):如果我们只需要验证Action中指定的方法只需要修改xml的文件名
文件命名:
语法:ActionClassName-ActionName-validation.xml
举例:UserAction-user_register-validation.xml
验证UserAction中的register方法
验证总结
代码:
重写validate() , 验证action所有方法
Validate方法名(), 验证指定“方法名”的方法
Xml:
验证所有方法: ActionClassName-validation.xml
验证指定方法: ActionClassName-actionName-validation.xml
代码验证,
比较灵活,可以满足所有的需求.
比较繁琐,要写重复的验证判断逻辑!
适合: 表单字段较少的情况用!
XML验证:
通用,但不够灵活; 可以验证特定简单的业务。
适合: 验证表单字段较多,可以大大简化代码!
(配置文件过多)
验证错误处理
Struts在进行数据效验的时候,验证失败,会返回input视图,要求我们要在struts.xml中配置input视图对应的错误页面!
配置:
Struts.xml |
<!-- 注册失败跳转到注册页面,显示失败信息 --> <global-results> <result name="input">/register.jsp</result> </global-results> |
Jsp显示错误
Ø 方式1:显示所有错误
<%@taglib uri="/struts-tags" prefix="s" %> <!-- 显示的是struts在运行时期产生的所有错误 --> <s:fielderror></s:fielderror> |
Ø 方式2:显示指定的错误
<!-- 修改struts标签默认的样式: 不让换行 --> <style type="text/css"> ul{ display: inline; } ul li{ display: inline; color: red; } </style> |
显示指定的错误: |
<s:fielderror fieldName="user.userName"></s:fielderror> |
Ø 方式3: 修改标签定义的模板
找到fielderror标签定义的模板文件:
Struts-core.jar\template\simple\ fielderror.ftl
把修改后的fielderror.ftl文件,放到src/ template/ simple/ fielderror.ftl
这样标签显示的样式就修改了!