struts2自定义验证器(身份证验证) - 编程入门网
struts2自定义验证器(身份证验证)时间:2011-08-31struts2的验证器是用的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 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |