<?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 '身份证号码错误';
}
|