struts2_12_struts2中的输入校验

来源:互联网 发布:福建省网络教育平台 编辑:程序博客网 时间:2024/06/14 04:18

(一)采用手工编写代码实现校验:

通过重写validate()方法实现,validate()方法会校验action中的所有与execute方法签名相同的方法,当某个数据校验失败时,应该调用addFileError()方法往系统的fieldErrors添加校验失败信息(为了使用addFileError()方法,action可以继承actionSupport),如果系统的fileError包含失败信息,struts2会将请求转发到名为input的result中,跳转回登录页面,在show.jsp视图中可以显示成功时的信息。 

在index.jsp页面中使用标签<s:fielderror/>显示失败信息。

1)struts中的代码:

<struts><package name="packageName" namespace="/test"   extends="struts-default"><action name="hello*" class="test.HelloAction"   method="{1}"><result name="input">/index.jsp</result><result name="success">/show.jsp</result></action></package></struts>

2)Action类中的方法:

public class HelloAction extends ActionSupport {private String username;private String mobile;public String getUsername() {return username;}public void setUsername(String username) {this.username = username;}public String getMobile() {return mobile;}public void setMobile(String mobile) {this.mobile = mobile;}public String update() {ActionContext.getContext().put("message", "更新成功");return "success";}public String save() {ActionContext.getContext().put("message", "保存成功");return "success";}public void validate() {// 会对所有方法校验if (this.username == null || "".equals(this.username.trim())) {this.addFieldError("username", "用户名不能为空");}if (this.mobile == null || "".equals(this.mobile.trim())) {this.addFieldError("mobile", "手机号不能为空");} else {if (!Pattern.compile("^1[358]\\d{9}$").matcher(this.mobile).matches()) {this.addFieldError("mobile", "手机号格式不正确");}}}}

3)输入页面index.jsp中的代码:

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%><%@ taglib uri="/struts-tags" prefix="s"%><!-- 添加标签 --><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"><html><head><title>input checkout</title><meta http-equiv="pragma" content="no-cache"><meta http-equiv="cache-control" content="no-cache"></head><body><s:fielderror /><!-- 使用标签打印错误信息 --><form action="${pageContext.request.contextPath}  /test/hellosave.action" method="post">用户名:<input type="text" name="username" />不能为空<br /> 手机号:<input type="text" name="mobile" />不能为空,并且要符合手机号的格式1,3/5/8,后面是9个数字<br /> <input type="submit" value="提 交" /></form></body></html>

4)显示层show.jsp中的代码:

<body>${message }<br></body>

注:若Action中的拦截方法写为

  public void validateMethodName() {}

此时只对action中的这一种方法进行校验。

当action中同时存在validate()方法和validateMethodName()方法时,将先调用validateMethodName()方法,然后再调用validate()方法。

输入校验的流程:

1>类型转换器对请求参数执行类型转换,并把转换后的值赋给action中的属性。

2>如果在执行类型转换器的过程中出现异常,系统会将异常保存到 

  ActionContext中,conversionErrors拦截器将异常信息添加到 

  fieldErrors里,不管类型转换是否发生异常,都会进入第三步。

3>系统通过反射技术先调用action中的validateMethodName()方法,若该方法 

  不存在,则调用action中的validate()方法。

4>经过上述步骤,如果系统中的fieldErrors存在错误信息(即存放错误信息

  的集合的size大于0),系统将自动请求转发至名称为input的视图。如果系统

  中的fieldErrors没有任何错误信息,系统将执行action中的处理方法。

()基于XML配置方法对action的校验

1.所有Action方法进行输入校验:

使用基于XML配置方法实现校验时,Action也要继承ActionSupport,并且提供校验文件和Action类放在同一个包下,文件名格式为:ActionClassName-validation.xml,其中ActionClassName为简单类名,-validation.xml为固定写法。校验文件的固定写法:

Struts.xml文件、index.jsp文件、show.jsp文件和()中的相同。 

1)HelloAction中的代码:

public class HelloAction extends ActionSupport {private String username;private String mobile;public String getUsername() {return username;}public void setUsername(String username) {this.username = username;}public String getMobile() {return mobile;}public void setMobile(String mobile) {this.mobile = mobile;}public String update() {ActionContext.getContext().put("message", "更新成功");return "success";}public String save() {ActionContext.getContext().put("message", "保存成功");return "success";}}

2)校验类的代码:

<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE validators PUBLIC "-//OpenSymphony Group//XWork Validator 1.0.3//EN" "http://www.opensymphony.com/xwork/xwork-validator-1.0.3.dtd"> <validators>    <field name="username">        <field-validator type="requiredstring">            <message>用户名不能为空!</message>        </field-validator>    </field>    <field name="mobile">        <field-validator type="requiredstring">            <message>手机号不能为空!</message>        </field-validator>        <field-validator type="regex">     <param name="expression"><![CDATA[^1[358]\d{9}$]]></param>     <message>手机号格式不正确!</message></field-validator>    </field></validators>

说明:同一个属性可以使用多条校验。多条校验放在同一个 

<field name="校验属性的名字"></field>中。<field>指定Action中要校验的属性, <field-validator>指定校验器,校验器requiredstring表示:该属性为必填字符串。

系统提供了能满足大部分验证需求的校验器,这些校验器,可以xwork-2.x.jar中的com.opensymphony.xwork2.validator.validators下的default.xml中找到。

<message>为校验失败后的提示,如果需要国际化,可以为message指定key属性,key的值为资源文件中的key

校验器的例子:

1>email:邮件地址校验器

<field-validator type="email"><message>电子邮件地址无效</message></field-validator>

2>regex:正则表达式

 <field-validator type="regex"> <param name="expression"><![CDATA[^1[358]\d{9}$]]></param> <message>手机号格式不正确!</message></field-validator>

3>required:属性必须填写的校验器

<field-validator type=”required”><message>提示必须填写的属性</message></feild-validator>

4>requiredstring:必填字符串校验器

 <field-validator type="requiredstring">//去掉前头和后头的空白字符<param name="trim">true</param><message>提示必须填写字符串属性</message></field-validator>

5>stringlength:字符串长度校验器

<field-validator type=”stringlength”><param name="maxLength">10</param><param name="minLength">3</param>//去掉前头和后头的空白字符<param name="trim">true</param><message><![CDATA[产品名称应在2-10个字符之间]]></message></field-validator>

6>int:证书校验器

 <field-validator type=”int”>  <param name="main">1</param>  <param name="max">150</param>  <message>年龄必须在1-150之间</message></field-validator>

7>字段OGNL表达式校验器

<field name="imagefile"> <field-validator type="fieldexpression"> <param name="expression">   <![CDATA[imagefile.length()<=0]]>        </param> <message>文件不能为空</message> </field-validator></field>

2.对指定的Action方法进行校验:

  其它与上面相同,只需更改校验文件格式名:

  ActionClassName-actionNameMethodName-validation.xml,其中  

  ActionClassName为简单类名,actionNameMethodNameAction的名字和

  Action中的要调用方法的名字,-validation.xml为固定写法

注:当为某个Action提供了两种校验规则文件时,系统安先全局后特定的顺序搜索,即搜索到全局校验文件时继续搜索特定的校验文件,然后把里面的所有教研规则汇总,全部应用于Action方法的校验。如果两个校验文件中指定的校验冲突,则使用特定校验文件规则。

当Action继承了某个Action是,父类acting的校验文件会先被搜索到,然后是子类的校验文件,最后汇总应用于Action。




















2 0
原创粉丝点击