时间:2021-05-26
本文实例讲述了PHP实现15位身份证号转18位的方法。分享给大家供大家参考,具体如下:
第一代身份证:15位身份证号码的意义
1-2位省、自治区、直辖市代码;
3-4位地级市、盟、自治州代码;
5-6位县、县级市、区代码;
7-12位出生年月日,比如670401代表1967年4月1日,这是和18位号码的第一个区别;
13-15位为顺序号,其中15位男为单数,女为双数;
与18位身份证号的第二个区别:没有最后一位的校验码。
第二代身份证:18位身份证号码的意义
①前1、2位数字表示:所在省份的代码,河南的省份代码是41哦!
②第3、4位数字表示:所在城市的代码;
③第5、6位数字表示:所在区县的代码;
④第7~14位数字表示:出生年、月、日;
⑤第15、16位数字表示:所在地的派出所的代码;
⑥第17位数字表示性别:奇数表示男性,偶数表示女性;
⑦第18位数字是校检码:也有的说是个人信息码,一般是随计算机随机产生,用来检验身份证的正确性。校检码可以是0~9的数字,有时也用x表示。
代码示例:
<?phpfunction CardId15To18($card){ $len = strlen($card); if($len == 18){ return $card; }else if($len != 15){ return false; } $result = array(); for($i=0;$i<$len;$i++){ if($i<=5){ $result[$i] = intval($card[$i]); }else{ //15位的年份是两位数,18位的是4位数,留出2位 $result[$i+2] = intval($card[$i]); } } //留出的2位,补充为年份,年份最后两位小于17,年份为20XX,否则为19XX if(intval(substr($card,6,2)) <= 17){ $result[6] = 2; $result[7] = 0; }else{ $result[6] = 1; $result[7] = 9; } ksort($result); //计算最后一位 //前十七位乘以系数[7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2], $arrInt = array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2); $sum = 0; for($i=0;$i<17;$i++){ $sum += $result[$i] * $arrInt[$i]; } //对11求余,的余数 0 - 10 $rod = $sum % 11; //所得余数映射到对应数字即可 $arrCh = array('1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2'); $result[17] = $arrCh[$rod]; return implode('',$result);}参考文章:https://www.jb51.net/article/172059.htm
PS:这里再为大家推荐一款相似的在线工具供大家参考:
身份证归属地信息在线查询:
http://tools.jb51.net/bianmin/sfz
另外,本站在线工具小程序上也有一款功能更加强大的身份证信息获取工具,感兴趣的朋友可以扫描如下小程序码查看:
更多关于PHP相关内容感兴趣的读者可查看本站专题:《PHP数学运算技巧总结》、《php字符串(string)用法总结》、《PHP数组(Array)操作技巧大全》、《PHP数据结构与算法教程》、《php程序设计算法总结》及《php正则表达式用法总结》
希望本文所述对大家PHP程序设计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
现在我们使用的都是18位身份证号,而以前都是15位身份证号,而如何将15位身份证号转18位身份证号转换为18位身份证号呢?1、首先,在15位身份证的第6位之后加
本文实例讲述了Java根据身份证号计算年龄,15位身份证号码转18位。分享给大家供大家参考,具体如下:第一代身份证:15位身份证号码的意义15位身份证号码各位的
编写程序前先来了解下身份证号的构成:身份证号分为两种,旧的为15位,新的为18位。身份证15位编码规则:ddddddyymmddxxp其中dddddd:地区码y
新公司框架源码的时候,发现了这个功能,于是搜索一番并封装了一下身份证号校验的类。目前大家的身份证号大多是18位的,当然,也不排除有些老人的身份证号是15位的。如
本例主要介绍如何在Excel中根据身份证号计算年龄和性别。 1、首先看一下原始数据,本例以18位身份证号为例。A列是18位的身份证号,需要在B列和C列分别