`

struts2自定义验证器(身份证验证)

阅读更多
struts2的验证器是用的xwork里面的验证,自定义验证器就是根据源码继承已有的字段验证器而来。具体步骤如下:
1.展开xwork-2.0.4.jar,com.opensymphony.xwork2.validator.validators目录下有个default.xml,将它复制到项目根目录下改名叫validators.xml。
验证框架首先在根目录下找validators.xml文件,没找到validators.xml文件,验证框架将调用默认的验证设置,即default.xml里面的配置信息.
4.新建一个类(身份证验证为例:类名CardIdFieldValidator)继承FieldValidatorSupport,实现validate方法。
package org.siyn.commons.validators;

import com.opensymphony.xwork2.validator.ValidationException;
import com.opensymphony.xwork2.validator.validators.FieldValidatorSupport;

public class CardIdFieldValidator extends FieldValidatorSupport
{

    
public void validate(Object object) throws ValidationException
    
{
        
// 获得字段的名字
        String fieldName = getFieldName();
        
// 获得输入界面输入的值
        String value = getFieldValue(fieldName, object).toString();

        
if (value == null || value.length() <= 0)
            
return;
        
        
if(value.length()!=15 && value.length()!=18 )//身份证必须是15或18位!
            addFieldError(fieldName, object);
        
        
if(value.length()==15)
            validate15CardId(value, object);
        
if(value.length()==18)
            validate18CardId(value, object);
    }

    
    
/** *//**
     * <p>18位身份证验证</p>
     * 
     * 根据〖中华人民共和国国家标准 GB 11643-1999〗中有关公民身份号码的规定,公民身份号码是特征组合码,由十七位数字本体码和一位数字校验码组成。
     * 排列顺序从左至右依次为:六位数字地址码,八位数字出生日期码,三位数字顺序码和一位数字校验码。
     * 
     * 第十八位数字(校验码)的计算方法为: 
     * 1.将前面的身份证号码17位数分别乘以不同的系数。从第一位到第十七位的系数分别为:7 9 10 5 8 4 2 1 6 3 7 9 10 5 8 4 2 
     * 2.将这17位数字和系数相乘的结果相加。 
     * 3.用加出来和除以11,看余数是多少? 
     * 4.余数只可能有0 1 2 3 4 5 6 7 8 9 10这11个数字。其分别对应的最后一位身份证的号码为1 0 X 9 8 7 6 5 4 3 2。 
     * 5.通过上面得知如果余数是2,就会在身份证的第18位数字上出现罗马数字的Ⅹ。如果余数是10,身份证的最后一位号码就是2。
     * 
     * @date Oct 18, 2008
     * 
@param value
     * 
@param object
     
*/

    
public void validate18CardId(String value, Object object)
    
{
        
// 获得字段的名字
        String fieldName = getFieldName();
        
        String tempStr 
= value.substring(0,17);
        String sourceCheckCode 
= value.substring(17,18);
        String checkCode 
= "";   
        
int[] a = new int[17];   
        
int i = 0;   
        
try
        
{
            
while(i<17){   
                a[i] 
= Integer.parseInt(tempStr.substring(i,i+1));   
                i
++;   
            }

        }
 catch (NumberFormatException e)
        
{
            addFieldError(fieldName, object);
        }
   
        
int mod = (a[0]*7+a[1]*9+a[2]*10+a[3]*5+a[4]*8+a[5]*4+a[6]*2+a[7]*1+a[8]*6+a[9]*3+a[10]*7  
            
+a[11]*9+a[12]*10+a[13]*5+a[14]*8+a[15]*4+a[16]*2)%11;   
        
switch (mod){   
            
case 10:    checkCode = "2";    break;   
            
case 9:     checkCode = "3";    break;   
            
case 8:     checkCode = "4";    break;   
            
case 7:     checkCode = "5";    break;   
            
case 6:     checkCode = "6";    break;   
            
case 5:     checkCode = "7";    break;   
            
case 4:     checkCode = "8";    break;   
            
case 3:     checkCode = "9";    break;   
            
case 2:     checkCode = "x";    break;   
            
case 1:     checkCode = "0";    break;   
            
case 0:     checkCode = "1";    break;   
        }
 
        
        
if(!sourceCheckCode.equalsIgnoreCase(checkCode))
            addFieldError(fieldName, object);
    }

    
    
/** *//**
     * <p>15位身份证验证</p>
     * 
     * 只做了数字验证
     * @date Oct 18, 2008
     * 
@param value
     * 
@param object
     
*/

    
public void validate15CardId(String value, Object object)
    
{
        String fieldName 
= getFieldName();
        
int i = 0
        
try
        
{
            
while(i<15){   
                
if(!Character.isDigit(value.charAt(i)))
                    addFieldError(fieldName, object);
                i
++;   
            }

        }
 catch (NumberFormatException e)
        
{
            addFieldError(fieldName, object);
        }

    }

}

5.在validators.xml中添加一个validator节点,和其他validator一样指定名称和类名,这里指定的name就是你将来要是使用的类型名字。
<validator name="cardid" class="org.siyn.commons.validators.CardIdFieldValidator"/>
到此自定义验证器就完成,剩下的就和使用自带的验证器一样了
6.新建action,继承ActionSupport或Action都行,写上相应需要验证的属性字段
7.新建验证文件xxxx-validation.xml,这个xxxx就是你前面action的类名字,xxx-xxx-validation.xml第二个xxx表示是jsp中的form提交action。
<field name="student.sfzh">
        
<field-validator type="requiredstring" short-circuit="true">
            
<message>身份证号不能为空.</message>
        
</field-validator> 
        
<field-validator type="cardid">
            
<message>身份证号格式不正确.</message>
        
</field-validator>
    
</field>

8.配置struts.xml,以及action.
...

分享到:
评论

相关推荐

    struts2 自定义验证程序的实现方法详解

    Struts2 提供了一个强大的验证框架,允许用户创建自定义验证器来满足各种需求。 #### 二、自定义验证程序的实现 ##### 1. 实现 Validator 接口 为了实现自定义的验证器,首先需要继承或实现 Struts2 的 Validator...

    struts 2.0自定义验证器

    自定义验证器通常是一个实现了`org.apache.struts2.validator.Validator`接口的Java类。你需要覆盖`validate`方法,该方法接受一个`ActionContext`对象和`FieldErrors`对象,用于存放验证错误。在这个方法内,编写...

    struts2 自定义标签

    在Struts2中,自定义标签是提高代码可读性和可维护性的重要工具。本文将深入探讨Struts2自定义标签的实现机制、优点以及如何在实际项目中进行应用。 一、Struts2自定义标签的概念 自定义标签是JSP的一种扩展,允许...

    struts2自定义拦截器

    简单的struts2自定义拦截器 很适合web初学者

    struts验证器validator使用,以及自定义验证器

    自定义验证器需要实现`org.apache.struts2.validator.FieldValidator`接口,重写`validate()`方法。然后在`validation.xml`中指定自定义验证器类型。 例如,创建一个检查邮箱格式的自定义验证器: ```java public ...

    struts2自定义结果类型demo

    本示例"struts2自定义结果类型demo"旨在演示如何在Struts2中创建并使用自定义结果类型。首先,我们需要了解Struts2的结果类型工作原理: 1. **默认结果类型**: - Struts2提供了一些内置的结果类型,如`dispatcher...

    Struts2自定义分页标签

    本资源详细介绍了如何在Struts2中自定义分页标签,使得开发过程更加便捷。 在Struts2中,分页通常涉及到以下几个关键步骤: 1. **创建Action类**:首先,你需要创建一个Action类,该类将处理用户的请求,包括获取...

    Struts2自定义标签

    Struts2作为一款流行的Java Web框架,极大地简化了MVC(模型-视图-控制器)应用的开发。自定义标签是Struts2框架中的一个重要特性,它允许开发者创建自己的标签库,以更直观、易读的方式在JSP页面中处理业务逻辑。...

    Struts2自定义校验框架

    自定义校验器是Struts2验证机制的核心部分。要创建一个自定义校验器,需要继承`org.apache.struts2.validator.FieldValidatorSupport`类或者实现`org.apache.struts2.validator.Validator`接口。然后在自定义校验器...

    struts2自定义拦截器配置心得

    Struts2自定义拦截器的配置是Struts2框架中一个非常重要的功能,它允许开发者在Action执行前后插入自定义的逻辑,以实现如权限验证、日志记录、性能监控等多种需求。以下是对标题和描述中涉及的知识点的详细说明: ...

    Struts2自定义拦截器

    在深入探讨自定义拦截器之前,我们先理解一下Struts2拦截器的基本概念。 拦截器(Interceptor)是基于Java的动态代理机制实现的,它可以拦截用户的请求,对请求进行预处理,并且在Action执行后进行后处理。通过在...

    使用struts2拦截器对登陆权限验证

    在Struts2中,拦截器(Interceptor)扮演着至关重要的角色,它允许开发者在动作执行前后插入自定义逻辑,如日志记录、权限验证等。在本案例中,我们将深入探讨如何使用Struts2拦截器实现登录权限验证,同时结合...

    struts2 自定义拦截器.rar

    自定义拦截器是Struts2框架中一个非常重要的特性,允许开发者扩展和定制框架的行为,以满足特定的业务需求。这篇博客文章可能是关于如何在Struts2中创建和使用自定义拦截器的教程。 在Struts2中,拦截器是基于责任...

    struts2实例 自定义过滤器 文件上传下载 登录功能

    本实例展示了如何在Struts2环境中实现几个关键功能:自定义过滤器、文件上传下载以及用户登录功能。这些功能是任何Web应用程序的基础组成部分,理解和掌握它们对于提升Web开发技能至关重要。 首先,我们来探讨...

    struts2自定义标签案例详解

    Struts2是一个强大的MVC框架,它允许开发者创建复杂、可扩展的Web应用程序。在Struts2中,自定义标签的实现是...通过Struts2的自定义标签,开发者能够更加灵活地控制视图层的呈现,同时保持与模型和控制器的松耦合。

    struts2自定义类型转换器

    文件名`struts2-6-test-2`可能包含了相关的测试代码或配置,用于验证自定义类型转换器的效果。 自定义类型转换器允许我们更灵活地处理数据绑定过程中的类型转换问题,提高代码的可维护性和可扩展性。通过以上步骤,...

    JSP 开发之Struts2内建自定义拦截器.docx

    在Struts2中,拦截器(Interceptor)扮演着关键角色,它们允许开发者在Action执行前后插入自定义逻辑,比如日志记录、权限验证、数据校验等。本文将深入探讨Struts2的内建自定义拦截器及其配置。 首先,让我们理解...

Global site tag (gtag.js) - Google Analytics