身份证号检测工具
问题引出:
好几天前楼主在刷某头条的时候,看到一个关于身份证号逆向生成的代码,主要就是关于最后一位校验码的计算。于是,好奇心驱动着我查找关于身份证号的相关信息,最终总算找到点有用的东西,所以就手动写一个关于检测身份证号是否合法的程序代码。现在在这里分享出来供大家参考(本博文只提供部分关键代码,完整代码见github地址,有兴趣的小伙伴可以去看看)。
身份证号知识大讲堂:
1.现在的身份证号都是18位的,每一位都有自己所代表的含义,具体如下:
1)前1、2位数字表示:所在省份的代码;
2)第3、4位数字表示:所在城市的代码;
3)第5、6位数字表示:所在区县的代码;
4)第7~14位数字表示:出生年、月、日;
5)第15、16位数字表示:顺序码,表示在同一地址码所标识的区域范围内,对同年、月、日出生的人员编定的顺序号;
6)第17位数字表示性别:奇数表示男性,偶数表示女性;
7)第18位数字是校检码:也有的说是个人信息码,一般是随计算机的随机产生,用来检验身份证的正确性。校检码可以是0~9的数字,有时也用X表示。
2.关于最后一位校验码的计算方法如下:
1)将身份证前17位数字,分别乘于7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2并相加,得到total;
2)将total模11,得到余数m;
3)在数组array(1,0,X,9,8,7,6,5,4,3,2)中,用余数m作为下标取得对应的数字n;
3.身份证的安全问题也需要大家重视,不要随意地泄露自己的关键信息,尤