- 浏览: 2290142 次
- 性别:
- 来自: 成都
文章分类
- 全部博客 (357)
- J2EE (49)
- JavaScript (40)
- Spring (19)
- Struts (5)
- CSS (8)
- Hibernate (16)
- Java (67)
- DWR (4)
- JSON (3)
- XFIRE (1)
- Tomcat (1)
- Ant (2)
- 设计模式 (2)
- 经典收藏 (2)
- JSP (10)
- Linux (0)
- WebLogic (11)
- myeclipse (13)
- Buffalo (4)
- 文件上传相关 (1)
- oracle (33)
- html (6)
- JSTL (3)
- SVN (2)
- GIT (1)
- 孙卫琴(Java网络编程精解) (1)
- DOM4J (2)
- Swing (1)
- AJAX (1)
- Eclipse (5)
- 日志组件 (3)
- PowerDesigner (1)
- Jquery (22)
- IT技术开发相关网址 (1)
- Nutz (1)
- 其它 (1)
- Velocity (3)
- WebService (1)
- MySql (2)
- Android (1)
- Maven (2)
- Quartz (11)
- Lucene (1)
- springsource (1)
- Junit (1)
- Activiti (0)
最新评论
-
yzlseu:
拼凑,没有营养
Activiti进阶—分配组任务 -
zhangsenhao:
非常赞!代码很清楚
SpringMVC3.0+MyIbatis3.0(分页示例) -
xiamw2000:
分页写得不对,应该是 : order by ${orderNa ...
SpringMVC3.0+MyIbatis3.0(分页示例) -
sheertewtw:
...
SpringMVC:上传与下载 -
kingtoon:
...
XSS之xssprotect
参考资料
1 java实现的18位身份证格式验证算法
http://fanqiang.chinaunix.net/program/java/2006-06-22/4639.shtml
原码中有少许错误,我已经调整过来了
2 身份证效验规则,经典
http://since2006.com/blog/176
公民身份号码是特征组合码,由十七位数字本体码和一位数字校验码组成.排列顺序从左至右依次为:六位数字地址码,八位数字出生日期码,三位数字顺序码和一位数字校验码。
1、地址码
表示编码对象常住户口所在县(市、旗、区)的行政区划代码,按 GB/T 2260 的规定执行。
2、出生日期码
表示编码对象出生的年、月、日,按 GB/T 7408 的规定执行。年、月、日代码之间不用分隔符。例:某人出生日期为 1966年10月26日,其出生日期码为 19661026。
3、顺序码
表示在同一地址码所标识的区域范围内,对同年、同月、同日出生的人编定的顺序号,顺序码的奇数分配给男性,偶数千分配给女性。
4 、校验码
根据前面十七位数字码,按照ISO 7064:1983.MOD 11-2校验码计算出来的检验码。由(1,2,3,4,5,6,7,8,9,X)构成.
(1)十七位数字本体码加权求和公式
S = Sum(Ai * Wi), i = 0, ... , 16 ,先对前17位数字的权求和
Ai:表示第i位置上的身份证号码数字值
Wi:表示第i位置上的加权因子
Wi: 7 9 10 5 8 4 2 1 6 3 7 9 10 5 8 4 2
(2)计算模
Y = mod(S, 11)
(3)通过模得到对应的校验码
Y: 0 1 2 3 4 5 6 7 8 9 10
校验码: 1 0 X 9 8 7 6 5 4 3 2
下面举例说明该计算方法并用代码实现。
公式:Ax=(∑(Ai×Wi))(mod 11)…………………………(1)
i----表示身份证号码字符从右至左包括校验码在内的位置序号;
Ai----表示第i位置上的数字号码;
Ax----数字校验码的值;
Wi----示第i位置上的加权因子;
公式:Wi=(2^(i-1))(mod 11)…………………………(2)
设某男性公民身份号码为51310119820113001,首先得到各个变量:
i 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1
由公式(2)可得:
Wi 7 9 10 5 8 4 2 1 6 3 7 9 10 5 8 4 2 1
-------------------------------------------------------------------------------
Ai 5 1 3 1 0 1 1 9 8 2 0 1 1 3 0 0 1 Ax
Ai×Wi 35 9 30 5 0 4 2 9 48 6 0 9 10 15 0 0 2 A1
按照公式(1)计算:
∑(Ai×Wi)=(35+9+30+5+0+4+2+9+48+6+0+9+10+15+0+0+2)=184
184÷11=16+8/11
∑(Ai×Wi)(mod 11)=8
然后根据计算的结果,从下表中查出相应的校验码,X表示结果为10:
∑(Ai×WI)(mod 11) 0 1 2 3 4 5 6 7 8 9 10
校验码字符值Ai 1 0 X 9 8 7 6 5 4 3 2
根据上面的方法,查出计算结果为8的校验码为4所以该人员的公民身份号码应该为513101198201130014
最新调整及修改:
参考资料
1 JAVA代码验证身份证信息
http://www.blogjava.net/zeroline/archive/2011/01/03/342227.html
2 java身份证验证代码类
http://download.csdn.net/source/2967003
特别说明,第一个链接上的源码不是最新的,作者已经上传CSDN了
见奉上ZeroLine的源码
经过测试以下身份证验证不准确,作个参考吧!如身份证号码:124578457845784571
经过调整后的源码:
测试类
经典验证类:
相比第一个代码量更少! 推荐呀
经过改写后的javascript版本:
经过测试OK
身份证15位转换为18位,参考文章:15位身份证号码转18位的JSP程序
http://www.java3z.com/cwbwebhome/article/article5a/5105.jsp?id=7
Java版
JavaScrpt版本
验证15,18身份证号码的合法性
参考资料
1 js 验证 15位 、 18位 身份证
http://yanpinquan.blog.163.com/blog/static/281162892011510105435903/
2 用javascript验证身份证号码15位或18位
http://topic.csdn.net/t/20050923/10/4288822.html
这个方法不是很正确,正确的做法是:先将15转换为18位,在调用方法验证是否正确!
1 java实现的18位身份证格式验证算法
http://fanqiang.chinaunix.net/program/java/2006-06-22/4639.shtml
原码中有少许错误,我已经调整过来了
2 身份证效验规则,经典
http://since2006.com/blog/176
公民身份号码是特征组合码,由十七位数字本体码和一位数字校验码组成.排列顺序从左至右依次为:六位数字地址码,八位数字出生日期码,三位数字顺序码和一位数字校验码。
1、地址码
表示编码对象常住户口所在县(市、旗、区)的行政区划代码,按 GB/T 2260 的规定执行。
2、出生日期码
表示编码对象出生的年、月、日,按 GB/T 7408 的规定执行。年、月、日代码之间不用分隔符。例:某人出生日期为 1966年10月26日,其出生日期码为 19661026。
3、顺序码
表示在同一地址码所标识的区域范围内,对同年、同月、同日出生的人编定的顺序号,顺序码的奇数分配给男性,偶数千分配给女性。
4 、校验码
根据前面十七位数字码,按照ISO 7064:1983.MOD 11-2校验码计算出来的检验码。由(1,2,3,4,5,6,7,8,9,X)构成.
(1)十七位数字本体码加权求和公式
S = Sum(Ai * Wi), i = 0, ... , 16 ,先对前17位数字的权求和
Ai:表示第i位置上的身份证号码数字值
Wi:表示第i位置上的加权因子
Wi: 7 9 10 5 8 4 2 1 6 3 7 9 10 5 8 4 2
(2)计算模
Y = mod(S, 11)
(3)通过模得到对应的校验码
Y: 0 1 2 3 4 5 6 7 8 9 10
校验码: 1 0 X 9 8 7 6 5 4 3 2
下面举例说明该计算方法并用代码实现。
公式:Ax=(∑(Ai×Wi))(mod 11)…………………………(1)
i----表示身份证号码字符从右至左包括校验码在内的位置序号;
Ai----表示第i位置上的数字号码;
Ax----数字校验码的值;
Wi----示第i位置上的加权因子;
公式:Wi=(2^(i-1))(mod 11)…………………………(2)
设某男性公民身份号码为51310119820113001,首先得到各个变量:
i 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1
由公式(2)可得:
Wi 7 9 10 5 8 4 2 1 6 3 7 9 10 5 8 4 2 1
-------------------------------------------------------------------------------
Ai 5 1 3 1 0 1 1 9 8 2 0 1 1 3 0 0 1 Ax
Ai×Wi 35 9 30 5 0 4 2 9 48 6 0 9 10 15 0 0 2 A1
按照公式(1)计算:
∑(Ai×Wi)=(35+9+30+5+0+4+2+9+48+6+0+9+10+15+0+0+2)=184
184÷11=16+8/11
∑(Ai×Wi)(mod 11)=8
然后根据计算的结果,从下表中查出相应的校验码,X表示结果为10:
∑(Ai×WI)(mod 11) 0 1 2 3 4 5 6 7 8 9 10
校验码字符值Ai 1 0 X 9 8 7 6 5 4 3 2
根据上面的方法,查出计算结果为8的校验码为4所以该人员的公民身份号码应该为513101198201130014
最新调整及修改:
参考资料
1 JAVA代码验证身份证信息
http://www.blogjava.net/zeroline/archive/2011/01/03/342227.html
2 java身份证验证代码类
http://download.csdn.net/source/2967003
特别说明,第一个链接上的源码不是最新的,作者已经上传CSDN了
见奉上ZeroLine的源码
import java.util.Calendar; import java.util.GregorianCalendar; import java.util.HashMap; import java.util.Map; /** * 身份证验证的工具(支持5位或18位省份证)<br/> * 身份证号码结构: * <ol> * <li>17位数字和1位校验码:6位地址码数字,8位生日数字,3位出生时间顺序号,1位校验码。</li> * <li>地址码(前6位):表示对象常住户口所在县(市、镇、区)的行政区划代码,按GB/T2260的规定执行。</li> * <li>出生日期码,(第七位 至十四位):表示编码对象出生年、月、日,按GB按GB/T7408的规定执行,年、月、日代码之间不用分隔符。</li> * <li>顺序码(第十五位至十七位):表示在同一地址码所标示的区域范围内,对同年、同月、同日出生的人编订的顺序号, * 顺序码的奇数分配给男性,偶数分配给女性。</li> * <li>校验码(第十八位数):<br/> * <ul> * <li>十七位数字本体码加权求和公式 s = sum(Ai*Wi), i = 0,,16,先对前17位数字的权求和; * Ai:表示第i位置上的身份证号码数字值.Wi:表示第i位置上的加权因.Wi: 7 9 10 5 8 4 2 1 6 3 7 9 10 5 8 4 2;</li> *<li>计算模 Y = mod(S, 11)</li> *<li>通过模得到对应的校验码 Y: 0 1 2 3 4 5 6 7 8 9 10 校验码: 1 0 X 9 8 7 6 5 4 3 2</li> *</ul> *</li> *</ol> * *@author cxy *@since 2011-1-7 *@see {@link http://www.blogjava.net/zeroline/archive/2011/01/03/342227.html} */ public class IdcardUtil { final static Map<Integer, String> zoneNum = new HashMap<Integer, String>(); static { zoneNum.put(11, "北京"); zoneNum.put(12, "天津"); zoneNum.put(13, "河北"); zoneNum.put(14, "山西"); zoneNum.put(15, "内蒙古"); zoneNum.put(21, "辽宁"); zoneNum.put(22, "吉林"); zoneNum.put(23, "黑龙江"); zoneNum.put(31, "上海"); zoneNum.put(32, "江苏"); zoneNum.put(33, "浙江"); zoneNum.put(34, "安徽"); zoneNum.put(35, "福建"); zoneNum.put(36, "江西"); zoneNum.put(37, "山东"); zoneNum.put(41, "河南"); zoneNum.put(42, "湖北"); zoneNum.put(43, "湖南"); zoneNum.put(44, "广东"); zoneNum.put(45, "广西"); zoneNum.put(46, "海南"); zoneNum.put(50, "重庆"); zoneNum.put(51, "四川"); zoneNum.put(52, "贵州"); zoneNum.put(53, "云南"); zoneNum.put(54, "西藏"); zoneNum.put(61, "陕西"); zoneNum.put(62, "甘肃"); zoneNum.put(63, "青海"); zoneNum.put(64, "新疆"); zoneNum.put(71, "台湾"); zoneNum.put(81, "香港"); zoneNum.put(82, "澳门"); zoneNum.put(91, "外国"); } final static int[] PARITYBIT = {'1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2'}; final static int[] POWER_LIST = { 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2}; /** * * 身份证验证 * *@param s * 号码内容 *@return 是否有效 null和"" 都是false */ public static boolean isIdcard(String s){ if(s == null || (s.length() != 15 && s.length() != 18)) return false; final char[] cs = s.toUpperCase().toCharArray(); //校验位数 int power = 0; for(int i=0; i<cs.length; i++){ if(i==cs.length-1 && cs[i] == 'X') break;//最后一位可以 是X或x if(cs[i]<'0' || cs[i]>'9') return false; if(i < cs.length -1){ power += (cs[i] - '0') * POWER_LIST[i]; } } //校验区位码 if(!zoneNum.containsKey(Integer.valueOf(s.substring(0,2)))){ return false; } //校验年份 String year = s.length() == 15 ? getIdcardCalendar() + s.substring(6,8) :s.substring(6, 10); final int iyear = Integer.parseInt(year); if(iyear < 1900 || iyear > Calendar.getInstance().get(Calendar.YEAR)) return false;//1900年的PASS,超过今年的PASS //校验月份 String month = s.length() == 15 ? s.substring(8, 10) : s.substring(10,12); final int imonth = Integer.parseInt(month); if(imonth <1 || imonth >12){ return false; } //校验天数 String day = s.length() ==15 ? s.substring(10, 12) : s.substring(12, 14); final int iday = Integer.parseInt(day); if(iday < 1 || iday > 31) return false; //校验一个合法的年月日:已经得到校验了 /*if(!validate(iyear, imonth, iday)) return false;*/ //校验"校验码" if(s.length() == 15) return true; return cs[cs.length -1 ] == PARITYBIT[power % 11]; } private static int getIdcardCalendar() { GregorianCalendar curDay = new GregorianCalendar(); int curYear = curDay.get(Calendar.YEAR); int year2bit = Integer.parseInt(String.valueOf(curYear).substring(2)); return year2bit; } @Deprecated static boolean validate(int year, int imonth, int iday){ //比如考虑闰月,大小月等 return true; } public static void main(String[] args) { String [] idCard = {"124578457845784571","124578200402284571","510521195402201748","510522200402306644"}; for(String sfz : idCard){ System.out.println(isIdcard(sfz)); } } }
经过测试以下身份证验证不准确,作个参考吧!如身份证号码:124578457845784571
经过调整后的源码:
public class IDCard { // wi =2(n-1)(mod 11) final int[] wi = { 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2, 1 }; // verify digit final int[] vi = { 1, 0, 'X', 9, 8, 7, 6, 5, 4, 3, 2 }; private int[] ai = new int[18]; public IDCard() { } // verify public boolean Verify(String idcard) { if (idcard.length() == 15) { idcard = uptoeighteen(idcard); } if (idcard.length() != 18) { return false; } String verify = idcard.substring(17, 18); if (verify.equals(getVerify(idcard))) { return true; } return false; } // get verify public String getVerify(String eightcardid) { int remaining = 0; if (eightcardid.length() == 18) { eightcardid = eightcardid.substring(0, 17); } if (eightcardid.length() == 17) { int sum = 0; for (int i = 0; i < 17; i++) { String k = eightcardid.substring(i, i + 1); ai[i] = Integer.parseInt(k); } for (int i = 0; i < 17; i++) { sum = sum + wi[i] * ai[i]; } remaining = sum % 11; } return remaining == 2 ? "X" : String.valueOf(vi[remaining]); } // 15 update to 18 public String uptoeighteen(String fifteencardid) { String eightcardid = fifteencardid.substring(0, 6); eightcardid = eightcardid + "19"; eightcardid = eightcardid + fifteencardid.substring(6, 15); eightcardid = eightcardid + getVerify(eightcardid); return eightcardid; } }
测试类
IDCard idcard = new IDCard(); System.out.println(idcard.Verify(sfz));
经典验证类:
public class IdCardDemo { public boolean isIdCard(String arrIdCard) { int sigma = 0; Integer[] a = { 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2 }; String[] w = { "1", "0", "X", "9", "8", "7", "6", "5", "4", "3", "2" }; for (int i = 0; i < 17; i++) { int ai = Integer.parseInt(arrIdCard.substring(i, i + 1)); int wi = a[i]; sigma += ai * wi; } int number = sigma % 11; String check_number = w[number]; if (!arrIdCard.substring(17).equals(check_number)) { return false; } else { return true; } } }
相比第一个代码量更少! 推荐呀
经过改写后的javascript版本:
function isIdCard(arrIdCard){ var tag = false; var sigma = 0; var a = new Array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2 ); var w = new Array("1", "0", "X", "9", "8", "7", "6", "5", "4", "3", "2"); for (var i = 0; i < 17; i++) { var ai = parseInt(arrIdCard.substring(i, i + 1)); var wi = a[i]; sigma += ai * wi; } var number = sigma % 11; var check_number = w[number]; if (arrIdCard.substring(17) != check_number) { tag = false; } else { tag = true; } return tag; }
经过测试OK
身份证15位转换为18位,参考文章:15位身份证号码转18位的JSP程序
http://www.java3z.com/cwbwebhome/article/article5a/5105.jsp?id=7
Java版
/** * 身份证15位转换18位 * */ public static String idCard15To18(String ID15) { String ID18 = ""; if (ID15.length() == 18) { ID18 = ID15.toUpperCase(); } if (ID15.length() == 15) { int[] w = { 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2, 1 }; char[] A = { '1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2' }; String ID17 = ID15.substring(0, 6) + "19" + ID15.substring(6, 15); int[] ID17Array; ID17Array = new int[17]; for (int i = 0; i < 17; i++) { ID17Array[i] = Integer.parseInt(ID17.substring(i, i + 1)); } int s = 0; for (int i = 0; i < 17; i++) { s = s + ID17Array[i] * w[i]; } s = s % 11; ID18 = ID17 + Character.toString(A[s]); } return ID18; }
JavaScrpt版本
function idCard15To18(id){ var W = new Array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2, 1); var A = new Array("1", "0", "X", "9", "8", "7", "6", "5", "4", "3", "2"); var i,j,s=0; var newid; newid = id; newid = newid.substring(0,6)+"19"+newid.substring(6,id.length); for(i=0;i<newid.length;i++ ){ j= parseInt(newid.substring(i,i+1))*W[i]; s=s+j; } s = s % 11; newid=newid+A[s]; return newid; }
验证15,18身份证号码的合法性
参考资料
1 js 验证 15位 、 18位 身份证
http://yanpinquan.blog.163.com/blog/static/281162892011510105435903/
2 用javascript验证身份证号码15位或18位
http://topic.csdn.net/t/20050923/10/4288822.html
function checkIDCard (str) { //身份证正则表达式(15位) isIDCard1=/^[1-9]\d{7}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}$/; //身份证正则表达式(18位) isIDCard2=/^[1-9]\d{5}[1-9]\d{3}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{4}$/; //验证身份证,返回结果 return (isIDCard1.test(str)||isIDCard2.test(str)); }
这个方法不是很正确,正确的做法是:先将15转换为18位,在调用方法验证是否正确!
发表评论
-
【转载】Eclipse Class Decompiler——Java反编译插件
2018-06-24 11:09 1359参见:jd-eclipse 的安装和使用(最新版的) h ... -
java json-lib & jQuery & jsonp
2016-06-30 11:31 832参考链接: 1、http://hanqunfeng.iteye ... -
Java多线程序源码
2016-06-24 15:04 10391、《Java多线程编程核心技术》源代码(高洪岩) 2、Jav ... -
Spring & Junit
2016-05-27 13:18 7561 测试基类(BaseJunit4Test) import ... -
随机分配算法(Intege)
2016-01-08 13:05 5202参考资料: http://blog.csdn.net/yaer ... -
XSS之xssprotect
2012-12-07 23:03 29496参考资料 1 跨网站脚本 ... -
myeclispe之图解weblogic81配置
2011-11-07 10:11 1622一 创建Weblogic81域(如下图) 注意事项:一般 ... -
Java之Thread(线程题)
2011-10-31 12:33 1978特别说明:java线程相关的参考了张孝祥老师的代码 参考资料 ... -
Java之ThreadLocal(Synchronized)
2011-10-31 10:10 2697参考资料 1 深入研究java.lang.ThreadLoca ... -
Java之synchronized,wait,notify结合运用示例
2011-10-26 11:54 5939场景一:要求二个线程各 ... -
Java之synchronized深入应用
2011-10-23 08:03 1949参考资料 1 java synchronized详解 http ... -
Java之Timer入门
2011-10-11 15:32 1699参考资料 1 java中timer用 ... -
Java之线程(匿名内部类)
2011-10-10 16:36 164381 Thread对象 Thread t = new Thr ... -
Java之线程(join)
2011-10-10 15:39 1486运用场景:多个线程之间 ... -
Java之线程(synchronized,wait(),notify(),notifyAll())
2011-10-10 15:03 3256参考资料 Java多线程入门大全(适用于有一定基础者) htt ... -
Java之线程(sleep,线程名)
2011-10-10 13:09 9719参考资料 1 Java线程:创建与启动 http://lava ... -
Java之线程入门
2011-10-10 11:11 1538参考资料 1 Java线程:概 ... -
java之表反向生成类
2011-09-23 16:41 3488环境:XP+JDK1.5+Oracle10g 注意事项 1 请 ... -
java之线程, NIO学习资料
2011-09-19 12:13 1135Concurrent In Java 6 第一部分 集合 ... -
Java之BigDecimal
2011-09-15 10:12 18036参考资料 1 java.math.BigDecimal的用法 ...
相关推荐
Java 和 JavaScript 的香港身份证验证方法主要涉及对香港身份证号码格式的有效性检查,通过特定的算法来确定号码是否合法。在 Java 和 JavaScript 中,这个验证过程包括以下步骤: 1. **预处理身份证号码**: - 在...
### Struts2 + AJAX 实现无刷新验证身份证号是否已注册及正确性的技术解析 #### 一、背景介绍 ...例如,可以通过引入更复杂的验证算法来增强身份证号验证的安全性,或者增加更多的异常处理逻辑来提高系统的健壮性。
本话题主要介绍一个JavaScript身份证号码验证函数,该函数具备辨真伪的功能,并能兼容15位和18位的身份证号码。 身份证号码是由15位或18位数字组成,其中包含出生日期、地市级行政区域代码、顺序码和校验码。18位...
身份证号码分为15位和18位两种格式,其中18位号码是在15位基础上增加了一个4位出生年份以及一位校验码。本文将详细介绍如何使用正则表达式进行身份证号码的有效性和合理性验证。 #### 简单校验:正则表达式的使用 ...
// 身份证验证位值 var ValideCode = [1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2]; // 验证身份证函数 function IdCardValidate(idCard) { idCard = trim(idCard.replace(/ /g, "")); if (idCard.length == 15) { // ...
4. 校验算法:如校验码计算,用于验证身份证号码的合法性。 5. 网络通信:如果SDK支持远程身份证识别,那么可能会涉及到HTTP/HTTPS请求,以及JSON或其他数据格式的序列化和反序列化。 使用这样的SDK,开发者可以...
一代身份证的验证算法略有不同,但基本原理相同。考虑到目前二代身份证已广泛使用,一代身份证的验证在现代网络应用中可能不再常见。 综上所述,实现身份证号验证需要理解其结构和校验机制,并在前端和后端分别...
- **身份证验证**:验证中国身份证号码的合法性,通常需要更复杂的算法。 此外,还有其他功能类的JavaScript代码,如: - **时间与相关控件**:包括日历、时间控件、万年历等。 - **表单动态操作**:自动生成表单...
中国的身份证号码由18位数字组成,每一段数字都有其特定含义,揭示了持有人的出生地、出生日期、性别等关键个人信息。这个系统可能是以美观易用的界面呈现,方便用户直观地理解和获取这些信息。 首先,我们来深入...
18位身份证号码包含了出生日期、性别、地区编码等信息,并且通过特定算法计算出校验码,确保号码的唯一性和正确性。在Kettle中,我们可以编写自定义的脚本来实现15位到18位的转换。这通常涉及查找特定的规则,比如...
多语言支持:尽管OpenCV主要使用C++编写,但它提供了丰富的API绑定,支持包括C、Python、Java、MATLAB、JavaScript等多种编程语言,方便不同领域的开发者使用。 开源与免费:OpenCV遵循BSD开源许可证发布,用户...
描述中的“身份证号校验”是指通过数学算法来验证18位身份证号码的正确性。中国居民身份证号码由18位数字组成,其中包含了出生日期、性别、以及上述的行政区划代码。前6位表示出生年月日(yyMMdd),第7位到第14位为...
- 身份证号验证较为复杂,需要考虑地区代码、出生日期及校验位等多种因素,可以通过复杂的正则表达式或者专门的算法实现。 ### 二、功能类 #### 1. 时间与相关控件类 - **1.1 日历** - 可以使用第三方库如 `...
中国公民的身份证号码由18位数字组成,前6位代表地区代码,接下来的8位是出生日期,第17位表示性别,偶数代表女性,奇数代表男性,最后一位是校验码。解析身份证信息时,我们需要理解这些规则并编写相应的算法。 ...
要深入了解这个工具的工作原理,你需要查看JavaScript代码,找出验证算法。通常,这种验证会包括检查数字的校验位,这是一种通过特定数学计算确保号码准确无误的方法。此外,代码可能还会处理一些边界情况,比如空...
身份证号码效验通常涉及到一系列校验规则,如18位身份证号码的组成、奇偶位校验等。我们可以编写Java方法来实现这些校验规则,然后通过Ajax调用这个方法。 **四、Ajax身份证效验实现步骤** 1. **前端HTML表单设计*...
它可能包括信用卡验证、身份证验证或其他类型的卡片数据验证。验证过程确保输入的卡片信息有效且安全,防止欺诈行为。 "cardvalidate"这个工具或程序可能包含以下知识点: 1. **卡片验证算法**:如Luhn算法,这是...
输入身份证号码,可以验证其合法性并获取持证人的大致年龄和性别;输入手机号码,可以确定号码的运营商和归属地,这对于营销定位和欺诈预防非常有用。 此软件的实现可能涉及到以下技术知识点: 1. 数据库设计:...
### Java银行系统知识点详解 #### 一、引言 随着经济的发展和技术的进步,银行业务的电子化成为必然趋势。为了更好地服务客户并提高自身效率,银行系统的设计与开发显得尤为重要。本文将详细介绍一个基于Java技术...