快速业务通道

struts2自定义验证器(身份证验证) - 编程入门网

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-06-15

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

时间:2011-08-31

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。

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

时间:2011-08-31

*

* @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){ 

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号