Struts 的数据校验和验证框架

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>
		<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>
		</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>
</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>  		

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值