[PHP]身份证校验位的计算/ISO 7064:1983.MOD 11-..
时间:2010-06-26 来源:nsq029
[PHP]身份证校验位的计算/ISO 7064:1983.MOD 11-2 算法
[PHP]
<?
function iso7064($vString)
{
// ISO 7064:1983.MOD 11-2
// by [email protected]
$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]
[PHP]
<?
function iso7064($vString)
{
// ISO 7064:1983.MOD 11-2
// by [email protected]
$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]
相关阅读 更多 +