<?php
//身份证号码
$idcard = '432831196411150810';
//身份证每位对应的乘数(前17位对应的乘数, 最后一位为校验码)
//例如: 4 * 7 + 3 * 9 + 2 * 10 依次类推
$jiaoyan = [7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2];
//获取身份证最后一位(最后一位为校验码)
$lastnum = substr($idcard, -1, 1);
//去除身份证最后一位 (最后一位为校验码)
$idcard = rtrim($idcard, $lastnum);
$sum = 0;
//身份证每位数乘以相应的乘数在相加获得和
for ($i = 0; $i < strlen($idcard); $i++){
$sum += $idcard[$i] * $jiaoyan[$i];
}
//在用和除以 11 求模 看剩余的余数
$yu = $sum % 11;
//余数所对应的最后一位值
$verifyArr = [
0 => 1,
1 => 0,
2 => 'X',
3 => 9,
4 => 8,
5 => 7,
6 => 6,
7 => 5,
8 => 4,
9 => 3,
10 => 2
];
if($verifyArr[$yu] == $lastnum){
echo '身份证号码正确';
}else{
echo '身份证号码错误';
}
03-24
05-20
07-11
09-21
131

05-20
06-22
752

11-22
262

“相关推荐”对你有帮助么?
-
非常没帮助
-
没帮助
-
一般
-
有帮助
-
非常有帮助
提交