欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

Java 验证身份证 博客分类: Java Java算法身份证验证 

程序员文章站 2024-03-19 21:57:52
...
一、大陆身份证组成

大陆居民身份证号码中的地址码的数字编码规则为:

第一、二位表示省(自治区、直辖市、特别行政区)。
第三、四位表示市(地区、自治州、盟及国家直辖市所属市辖区和县的汇总码)。其中,01-      20,51-70表示省直辖市;21-50表示地区(自治州、盟)。
第五、六位表示县(市辖区、县级市、旗)。01-18表示市辖区或地区(自治州、盟)辖县级市;21-80表示县(旗);81-99表示省直辖县级市。
第七位到第十四位表示编码对象出生的年、月、日。
第十五位到十七位,地址码所标识的区域范围内,对同年、月、日出生的人员编定的顺序号。其中第十七位奇数分给男性,偶数分给女性。
第十八位表示校验码。取值为 0-9,x。

二、校验码计算方法
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、通过上面得知如果余数是3,就会在身份证的第18位数字上出现的是9。如果对应的数字是10,身份证的最后一位号码就是罗马数字x。

private boolean valiIdCard(String idcard) {

                /* 系数 权值 */
		int[] quan = new int[] { 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8,
				4, 2 };
		int sum = 0;

		if (idcard.length() == 18) {

			// 循环quan数组取得每个位置对应的整数
			for (int i = 0; i < quan.length; i++) {
				// charAt(),获得字符串对应下标的字符
				sum += quan[i] * (idcard.charAt(i) - '0');
			}


                       /* 相加的结果对11取余,用于匹配校验码 */
			int sum2 = sum % 11;

                       /* 
                        * 身份证校验码所有可能的取值 
                        * sum2 与 校验码对应的结果分别为
                        * sum2   < == >   校验码
                        *  0  < == > 1
                        *  1  < == > 0
                        *  2  < == > x
                        *  3  < == > 9
                        *  4  < == > 8
                        *  5  < == > 7
                        *  6  < == > 6
                        *  7  < == > 5
                        *  8  < == > 4
                        *  9  < == > 3
                        *  10 < == > 2
                        */
			char[] c = new char[] { '1', '0', 'x', '9', '8', '7', '6', '5',
					'4', '3', '2' };
			// 取出对应下标的字符,即为身份证第十八位
			char code = c[sum2];
			return code == idcard.charAt(17);
		}
		return false;

	}

上一篇: LCS-入门

下一篇: linux系统网络分析