Struts 2 的数据校验
对于一个web应用而言,所有的用户数据都是通过浏览器收集的,用户的输入信息非常复杂的,用户操作不熟练,输入出错,硬件设备不正常。网络传输的不稳定,甚至恶意用户的蓄意的破坏,这些都有等,这些都能可能导致输入异常。
异常输入,轻则导致系统非正常中断,重则导致系统崩溃,应用程序化必须能正确表现层接收的异常数据,通常的做法是遇到异常数输入时应用程序直接返回,提示浏览者必须重新输入,也就是将那些异常过滤掉,对异常输入的过滤就是数据检验。
通过struts2的数据验证机制。Action extends ActionSupport类。
com.opensymphony.xwork2.ActionSupport.
ActionSupport类:
execute() 直接返回 SUCCESS ;
验证,本地化的支持: 提供 validate(), addActionError(String errorMesage) ; addFiledError(String filedName, String errorMessage)等,来完成数据验证。
本地化支持,可以通过各种getText()方法来获取本地化文本。
一般的情况下的Action 类 的开发,均会选择继承此类,
下面就使用.ActionSupport 类继续完成登录功能。
第一步:将验证逻辑移至validate()方法
第二步:修改login.jsp 页面
缺点:1.当验证比较复杂时,需要些繁琐的代码进行实现。Action 臃肿
2.验证规则无法进行复用 扩展型低.
鉴于数据验证的重要性和重复性,Struts 2 中内置了一个验证框架,将常用的验证规则进行编程实现。使用验证框架时,用户无需再进行编码,只要在外部配置文件中指定某个字段需要进行验证类型,并提供错误信息即可,从而大大减轻了开发者的负担。提高了开发效率。
Struts 2验证框架
-----客服需求---------------------------------------
需求:用户注册功能使用验证框架进行验证。
1.用户名:不能为空,长度在6到10之间;
2.密码: 不能为空,密码长度不小于6
3.确认密码:必须和密码相同。
4.电话:不能为空,符合电话号码格式
5.用户姓名:不能为空,长度2到4之间。
-----分析-----------------------------------------------------
(1)创建RegisterAction,实现对用户注册的处理
(2 在 struts.xml 中配置 action 验证成功的跳转到首页,验证失败返回register.jsp,并显示错误信息
(3)创建注册页面register.jsp.
(4)创建验证文件RegisterAction-validation.xml使用验证框架编写验证规则。
------
我们按安照分析的总实现步骤,
(1) 创建RegisterAction ,实现对用户注册处理;
- package action;
-
-
- import bean.User;
-
- import com.opensymphony.xwork2.ActionSupport;
- /**
- * 用户注册
- * @author
- */
- public class RegisterAction extends ActionSupport {
-
- private User user; //用户对象
- private String repassword; //确认密码
- public String getRepassword() {
- return repassword;
- }
- public void setRepassword(String repassword) {
- this.repassword = repassword;
- }
- public User getUser() {
- return user;
- }
- public void setUser(User user) {
- this.user = user;
- }
- public String execute() {
- return SUCCESS;
- }
- }
bean.User.java
- package bean;
-
- public class User {
-
- private String usnername;
- private String password;
- private String name;
- private String telephone;
- public String getUsnername() {
- return usnername;
- }
- public void setUsnername(String usnername) {
- this.usnername = usnername;
- }
- public String getPassword() {
- return password;
- }
- public void setPassword(String password) {
- this.password = password;
- }
- public String getName() {
- return name;
- }
- public void setName(String name) {
- this.name = name;
- }
- public String getTelephone() {
- return telephone;
- }
- public void setTelephone(String telephone) {
- this.telephone = telephone;
- }
-
-
-
- }
2.在struts2.xml配置action
- <?xml version="1.0" encoding="UTF-8" ?>
- <!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.1//EN" "http://struts.apache.org/dtds/struts-2.1.dtd">
- <struts>
-
- <constant name="struts.custom.i18n.resources" value="message"/>
- <constant name="struts.i18n.encoding" value="UTF-8"/>
-
- <package name="struts2" extends="struts-default" namespace="/page">
- <action name="register" class="action.RegisterAction">
- <result name="success">index.jsp</result>
- <result name="input">/page/register1.jsp</result>
- </action>
- </package>
- </struts>
因为进行数据验证,所以需要指定验证失败后的返回页面。Struts 2中 通过"input"字符串来指定当输入出现验证错误时需要返回的错误时到页面。
3.创建注册页面register.jsp
- <h2>新用户注册</h2>
- lt;s:form action="register">
- <s:textfield name="user.name" label="用户名" />
- <s:password name="user.password" label="密码" />
- <s:password name="repassword" label="确认密码" />
- <s:textfield name="user.telephone" label="电话号码" />
- <s:textfield name="user.username" label="用户姓名" />
- <s:submit value="提交"></s:submit>
- <s:reset value="重置"></s:reset>
- lt;/s:form>
4. 创建验证文件,
使用验证框架编制验证规则。
验证文件和验证的Action放在同一个包下,并且采用ClassName-validate.xml 或者ClassName-alias-validate.xml的方式命名。其中ClassName表示Action的类名,而alias表示在struts.xml 中配置 action的名字,
创建验证文件 RegisterAction-validation.xml
validators 标签是验证文件的跟标签。
- <?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">
- <?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>
struts 2 提供验证器
1.requiredstring 验证器 用来规定一个字符串字不能为null,且不能为空字符串。
2.stringlength 验证器用来检查一个字符的长度范围,可以通过minLength和maxLength 两个参数才指定字段的最小长度和最长长度。
3.fiedexpression 验证器使用OGNL 表达式来验证字段,通过expression。参数来指定要计算的ONGL表达式,计算结果必须为boolean值,如果为true,验证通过 否则验证失败.
4.regex 验证器 使用正则表达式验证一个字符串,提供了expression 参数来指定具体的正则表达式。
- <?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="user.name">
- <field-validator type="requiredstring">
- <param name="trim">true</param>
- <message key ="name.null"/>
- </field-validator>
- <field-validator type="stringlength">
- <param name="maxLength">10</param>
- <param name="minLength">6</param>
- <message key ="name.length"/>
- </field-validator>
- </field>
- <field name="user.password">
- <field-validator type="requiredstring">
- <message key="password.null"/>
- </field-validator>
- <field-validator type="stringlength">
- <param name="minLength">6</param>
- <message key="password.length"/>
- </field-validator>
- </field>
- <field name="repassword">
- <field-validator type="requiredstring">
- <message key="repassword.null"/>
- </field-validator>
- <field-validator type="fieldexpression">
- <param name="expression">user.password==repassword</param>
- <message key="repassword.same"/>
- </field-validator>
- </field>
- <field name="user.telephone">
- <field-validator type="requiredstring">
- <message key="telephone.null"/>
- </field-validator>
- <field-validator type="regex">
- <param name="expression">^(\d{3,4}-){0,1}(\d{7,8})$</param>
- <message>电话号码格式不正确</message>
- </field-validator>
- </field>
- <field name="user.username">
- <field-validator type="requiredstring">
- <param name="trim">true</param>
- <message key="username.null"/>
- </field-validator>
- <field-validator type="stringlength">
- <param name="maxLength">4</param>
- <param name="minLength">2</param>
- <message key="username.length" />
- </field-validator>
- </field>
- </validators>