中國(guó)(大陸)公民身份證號(hào)碼每一位所代表的意義,網(wǎng)上很多文章都有介紹,在此就不多說(shuō)。其中身份證號(hào)碼的最后一位是校驗(yàn)碼,跟據(jù)前17位計(jì)算得到。算法大 概是這樣:把前17位的每一個(gè)數(shù)字和一串加權(quán)因子相乘,再計(jì)算這些乘積的和;把這些乘積的和模11得到的數(shù)字作為序號(hào),最后在一個(gè)校驗(yàn)碼串中提取出與序號(hào) 相對(duì)應(yīng)的字符。當(dāng)然,網(wǎng)上也有不少的文章教大家計(jì)算這個(gè)校驗(yàn)碼,下面我們將嘗試用PHP語(yǔ)言來(lái)完成這一工作,也許可以用于PHP開發(fā)中,如校驗(yàn)用戶的身份證號(hào)碼是否正確。
假設(shè)某中國(guó)(大陸)公民的身份證號(hào)碼前17位是這個(gè):44010221990101001(注:此人出生于2199年),那么我們跟據(jù)上面的算法嘗試寫幾行PHP代碼來(lái)完成校驗(yàn)碼的計(jì)算。為了能讓大家更容易理解,我使用了較簡(jiǎn)單的語(yǔ)句,請(qǐng)看代碼:
<?php
//身份證號(hào)碼前17位,可以從各種數(shù)據(jù)源中獲得(如數(shù)據(jù)庫(kù)、用戶提交的表單等)
$body = '44010221990101001';
//加權(quán)因子
$wi = array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2);
//校驗(yàn)碼串
$ai = array('1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2');
//按順序循環(huán)處理前17位
for ($i = 0;$i < 17;$i++) {
//提取前17位的其中一位,并將變量類型轉(zhuǎn)為實(shí)數(shù)
$b = (int) $body{$i};
//提取相應(yīng)的加權(quán)因子
$w = $wi[$i];
//把從身份證號(hào)碼中提取的一位數(shù)字和加權(quán)因子相乘,并累加
$sigma += $b * $w;
}
//計(jì)算序號(hào)
$number = $sigma % 11;
//按照序號(hào)從校驗(yàn)碼串中提取相應(yīng)的字符。
$check_number = $ai[$number];
//輸出
echo $body.$check_number;
?>
運(yùn)行以上代碼之后,可以算出該身份證的校驗(yàn)碼為9。大家可以用自己身份證的前17位試試。
如果你明白上面的例子的話,就可以把這段代碼的一些語(yǔ)句合并,去除沒(méi)必要的變量,優(yōu)化得到如下代碼:
<?php
$body = '44010221990101001';
$wi = array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2);
$ai = array('1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2');
for ($i = 0;$i < 17;$i++) {
$sigma += ((int) $body{$i}) * $wi[$i];
}
echo $body.$ai[($sigma % 11)];
?>
以上所述是小編給大家介紹的PHP身份證校驗(yàn)碼計(jì)算方法,希望對(duì)大家有所幫助