GB/T 17710-1999 PHP生成校驗碼

校驗碼算法描述如下:詳細:http://wenku.baidu.com/link?url=CDvNJ1sLYOPzbbxjEy5R-oME95RlfTCUU5-I5M0bqUt0I32b0Xd0EKmI-HiFQHhY8OcB6ERTml7pUwXFseLl8GGvkuc7w0V2sFDxi2H0XGC


wKiom1R4gOuRhayeAAGGxBwiMjg341.jpg

wKioL1R4gXCCxdhmAAHgZmAvdrU034.jpg

wKiom1R4gOvj6omKAAHya8Dpxfo240.jpg


本例子以16位編號爲例子,用PHP予以實現,代碼如下:

$m = '';
	$str = '440400131008309';
	$str.= 'a';
/* 測試用例,最後一位爲校驗碼
4404021110060840
4404001310083095
4404021150062404
*/
	function p($str,$n)
	{
		if ($n == 1)
		{
			return 10;
		}
		else
		{
			$num = $str[$n-2];
			$s = p($str,$n-1)%11 + $num;
			return ($s%10==0?10:$s%10)*2; 
		}
	}

	$p = p($str,16);
	for($i=0;$i<10;$i++){
		if (($p%11 + $i)%10 == 1){
			$m = $i;
			break;
		}
	}
	echo $m;


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章