您的位置:首页 > 编程语言 > PHP开发

[PHP]身份证校验位的计算/ISO 7064:1983.MOD 11-2 算法

2011-08-18 16:58 197 查看
[PHP]身份证校验位的计算/ISO 7064:1983.MOD 11-2 算法

[PHP]

<?

function iso7064($vString)

{

// ISO 7064:1983.MOD 11-2

// by goseaside@sina.com

$wi = array(1, 2, 4, 8, 5, 10, 9, 7, 3, 6);

$hash_map = array('1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2');

$i_size = strlen($vString);

$bModify = '?' == substr($vString, -1);

$i_size1 = $bModify ? $i_size : $i_size + 1;

for ($i = 1; $i <= $i_size; $i++) {

$i1 = $vString[$i - 1] * 1;

$w1 = $wi[($i_size1 - $i) % 10];

$sigma += ($i1 * $w1) % 11;

}

if($bModify) return str_replace('?', $hash_map[($sigma % 11)], $vString);

else return $hash_map[($sigma % 11)];

}

/*

// Demo

// $s 为某个 17 位身份证号码,不包含校验位

echo iso7064($s); // 获得校验位的值

echo iso7064("$s?"); // 包含校验位的结果

*/

?>

[/PHP]
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: