本文主要是介绍Java简单实例——身份证校验位的代码实现,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
文章目录
- 一、问题引入
- 二、可行性分析
- 1.算法原理
- 三、代码实现
- 1.步骤
- 四、完整代码
- 五、验证
一、问题引入
近些年,实名认证越来越严格,诚然这是一种对未成年人的保护措施,但是对于喜欢体验各种游戏的我而言,一些小厂商或小公司的游戏实名认证我不由得担忧起隐私问题,于是我查阅了一下关于身份证的资料。
根据〖中华人民共和国国家标准 GB 11643-1999〗中有关公民身份号码的规定,公民身份号码是特征组合码,由十七位数字本体码和一位数字校验码组成。排列顺序从左至右依次为: [1] 六位数字地址码,八位数字出生日期码,三位数字顺序码和一位数字校验码。
其中对于其中的几位数字我们已经熟知,比如中间的几位数字代表身份日期,前几位数字代表所在地区等等,但是最后一位很少人知其含义,有的人最后一位还是X。这个最后一位其实是一个校验位,说直白点就是验证你这个身份证是否合法的。
二、可行性分析
对于很多公司和厂商是没有权限去验证姓名和身份证是否匹配的(公安机关的户口档案可不是谁都可以进入的哦⚆_⚆),所以我们这个通过身份证验证位(编的身份证)可以通过很多游戏的实名验证
1.算法原理
身份证前17位每位对应一个固定的数字,类似权重值,即数组 7 9 10 5 8 4 2 1 6 3 7 9 10 5 8 4 2 ,然后用原先身份证数字与之相乘,然后求和,,最后得到的数字对11取余(至于为什么要对11这个神秘的数字取余,原理比较复杂,在此不多赘述了||-_- ),用余数的对应 1 0 X 9 8 7 6 5 4 3 2这个数组的第几位,就得到了身份证的校验位
举一个简单的例子:
比方说身份证前十七位为111…111(这里为了方便计算,取17个1),第一位对应的权重为7,第二位为9…第十七位为2,原身份证数字与之相乘之后得到的数字为7+9+10+…+2=100,然后对11取余,100%11余数为1,对应那个神秘数组的a[1],即第二位(一个数组是从a[0]开始的) 。最终这个(假)身份证的校验位为0
三、代码实现
1.步骤
- 首先,我们输入一个17位的文本信息
System.out.println("请输入身份证的前17位");String st = sc.next();if(st.length()!=17){ //字符串的长度用 length()System.out.println("长度不对,请重新输入");sc.close();return;}// 步骤1完成
- 将其转换成17个整数
int[] arr = new int[17];int[] bit = {7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2};//对应乘的数组 for(int i=0;i<arr.length;i++){char c = st.charAt(i); //'4'arr[i] = c - '0'; //数字字符转对应的数字}//步骤2完成
- 对应与 7 9 10 5 8 4 2 1 6 3 7 9 10 5 8 4 2 相乘,并求和。
int sum = 0;for(int i=0;i<arr.length;i++){sum = sum + arr[i]*bit[i];}//步骤3完成
- 求和结果对11取余数,用余数对应 1 0 X 9 8 7 6 5 4 3 2这个数组的第几位,并输出结果。
char[] res = {'1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2'};System.out.println(res[sum%11]);
四、完整代码
public class Card {public static void main(String[] args) {Scanner sc = new Scanner(System.in);System.out.println("请输入身份证的前17位");String st = sc.next();if(st.length()!=17){ //字符串的长度用 length()System.out.println("长度不对,请重新输入");sc.close();return;}// 步骤1完成int[] arr = new int[17];int[] bit = {7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2};//对应乘的数组 for(int i=0;i<arr.length;i++){char c = st.charAt(i); //'4'arr[i] = c - '0'; //数字字符转对应的数字}//步骤2完成int sum = 0;for(int i=0;i<arr.length;i++){sum = sum + arr[i]*bit[i];}//步骤3完成char[] res = {'1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2'};System.out.println(res[sum%11]);sc.close();
}}
五、验证
这篇关于Java简单实例——身份证校验位的代码实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!