struts 验证规则

struts验证规则的原理:

为了实现验证,需要在action中添加一个方法,比如要重写的validate()方法。假设action中还有一个register的方法.在执行这个register方法之前会执行struts的默认拦截器 <interceptor name="validation" class="org.apache.struts2.interceptor.validation.AnnotationValidationInterceptor"/>这个拦截器的底层维护了一个map集合,当验证不通过的时候就把错误信息添加到这个map中保存起来..然后转到input视图进行提示.

1.代码方式验证Action中所有方法的验证器

此Action必须继承ActionSupport类..因为要用到拦截器.

重写其中的validate()方法即可.

@Override
	public void validate() {
		//用户名非空
		if(user.getUsername()==null||"".equals(user.getUsername())){
			super.addFieldError("username", "用户名不能为空");
		}
		if(user.getPassword()==null||user.getPassword().length()<8){
			super.addFieldError("password", "密码不能为空,并且长度要大于8位");
		}
	}

2.代码方式验证Action 中指定方法验证器

命名规范validate+需要验证的方法名 如:validateRegister()那么这个验证器只对register方法有效

//验证指定的方法
	public void validateRegister() {
		//用户名非空
		if(user.getUsername()==null||"".equals(user.getUsername())){
			super.addFieldError("username", "用户名不能为空");
		}
		if(user.getPassword()==null||user.getPassword().length()<8){
			super.addFieldError("password", "密码不能为空,并且长度要大于8位");
		}
	}

3.xml方式验证Action中所有的方法

xml命名:ActionClassName+validation.xml 如:UserAction-validation.xml

这个xml需要放到和Action类同级的目录下面即可

<?xml version="1.0" encoding="UTF-8"?>

  <!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.username">
 		<field-validator type="requiredstring">
 			<message>用户名不能为空!</message>
 		</field-validator>
 	</field>
 	<field name="user.password">
 		<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>
 	<field name="user.date">
 		<field-validator type="date">
 			<message>日期格式不正确!</message>
 		</field-validator>
 	</field>
 	<field name="user.email">
 		<field-validator type="email">
 			<message>邮箱格式不正确!</message>
 		</field-validator>
 	</field>
 </validators>

4.xml方式验证Action类中指定的方法

xml命名规范:ActionClassName-ActonName-validation.xml 如UserAction-user_register-validation.xml

xml配置同3.

5.运行配置:

struts.xml 红色字体代表配置全局错误视图

<struts>
	<package name="user" extends="struts-default">
	<span style="color:#ff0000;"><global-results>
		<result name="input">/register.jsp</result>
	</global-results></span>
		<action name="user_*" class="cn.itcast.action.UserAction" method="{1}">
			<result name="register">/index.jsp</result>
			<result name="list">/index.jsp</result>
		</action>
	</package>
</struts>

register.jsp 红色字体的位置显示错误信息

<body>
   <form action="${pageContext.request.contextPath }/user_register" method="post">
   		<span style="color:#ff0000;"><s:fielderror></s:fielderror></span>
   		用户名:<input type="text"  name="user.username"/><br>
   		密码:<input type="text" name="user.password"/><br>
   		入职日期:<input type="text" name="user.date"/><br>
   		电子邮件:<input type="text" name="user.email"><br>
   		<input type="submit" value="提交"/>
   </form>
  </body>

版权声明:本文为博主原创文章,未经博主允许不得转载。

时间: 2024-10-10 06:52:21

struts 验证规则的相关文章

Struts2系列:(21)在Struts中自定义验证规则

1.Struts实现验证的过程 通过对Struts源代码的学习,总结一下Struts如何实现验证. 在struts-default.xml文件中,有validator和workflow两个拦截器. <interceptor name="validation" class="org.apache.struts2.interceptor.validation.AnnotationValidationInterceptor"/> <interceptor

Struts2 验证框架 validation.xml 常用的验证规则

Struts2 验证框架 validation.xml 常用的验证规则 validation.xml 的命名规则和放置路径:文件名:<ActionClassName>-validation.xml<ActionClassName>就是要验证的Action类的名字. 要将此文件放于Class文件相同的目录.如果在Action类在struts配置中有多个action实例(action name),那么对应某个action的验证文件名规则如下:文件名:<ActionClassNam

MVC中的验证规则

前面的博客中曾经提到过ModelBing机制,也在Demo中体现过,在MVC中更吊的是封装了自定义的验证规则.下面来一个Demo来展现一下,看了后,你一定会爱上它的,能让你少写很多JS语句. 1.View层 <span style="font-size:18px;">@*自动绑定实体模型*@ @model MvcApplication1.Models.User <h2>Login</h2> <form method="post&quo

[Asp.net MVC]Asp.net MVC5系列——在模型中添加验证规则

目录 概述 在模型中添加验证规则 自定义验证规则 伙伴类的使用 总结 系列文章 [Asp.net MVC]Asp.net MVC5系列——第一个项目 [Asp.net MVC]Asp.net MVC5系列——添加视图 [Asp.net MVC]Asp.net MVC5系列——添加模型 [Asp.net MVC]Asp.net MVC5系列——从控制器访问模型中的数据 [Asp.net MVC]Asp.net MVC5系列——添加数据 概述 上篇文章中介绍了添加数据,在提交表单的数据的时候,我们需

报错:非介入式客户端验证规则中的验证类型名称必须唯一。下列验证类型出现重复

当在ASP.NET MVC中,针对一个Model进行添加操作的时候,报如下错误: [InvalidOperationException: 非介入式客户端验证规则中的验证类型名称必须唯一.下列验证类型出现重复: range] 原因是第三方验证程序集和MVC固有验证发生名称的冲突. 解决办法:在Model中属性上注释掉第三方程序集提供的验证特性.

Yii CModel中rules验证规则

array( array(‘username’, ‘required’),  array(‘username’, ‘length’, ‘min’=>3, ‘max’=>12),  array(‘password’, ‘compare’, ‘compareAttribute’=>’password2′, ‘on’=>’register’),  array(‘password’, ‘authenticate’, ‘on’=>’login’), array(‘Price’,’num

JQuery validate验证规则

//定义中文消息 var cnmsg = { required: "必选字段", remote: "请修正该字段", email: "请输入正确格式的电子邮件", url: "请输入合法的网址", date: "请输入合法的日期", dateISO: "请输入合法的日期 (ISO).", number: "请输入合法的数字", digits: "只能输入整数

2016/05/15 ThinkPHP3.2.2 表单自动验证实例 验证规则的数组 直接写在相应的控制器里

使用TP 3.2框架 验证规则也可以写到模型里,但感觉有些麻烦, 一是有时候不同页面验证的方式会不一样, 二是看到这个   Add  事件里的代码,就清楚要接收什么数据,如何验证数据能够在第一眼有个大致了解 ①控制器代码页 1 <?php 2 namespace Home\Controller; 3 use Think\Controller; 4 5 header("Content-type: text/html; charset=utf-8"); 6 7 class AddCo

YII 表单验证规则大全

<?php class ContactForm extends CFormModel { public $_id; public $contact;//联系人 public $tel;//电话 public $fax;//传真 public $zipcode;//邮编 public $addr;//地址 public $mobile;//手机 public $email;//邮箱 public $website;//网址 public $qq;//QQ public $msn;//MSN pub