最近因公司需求寫了點API
其中需要一些銀行卡號的信息關於這個驗證正則找了很多都是些大致性的校驗比如數字拉位數啦,後來發現一哥們寫了個比較詳細的介紹銀行卡的生成規則 做個小總結
檢定數位演算法(Luhn Check Digit Algorithm) 也叫作模數10公式是一種簡單的演算法,用來驗證銀行卡、信用卡號碼的有效性的演算法。對所有大型信用卡公司發行的信用卡都起作用,這些公司包括美國Express、護照、萬事達卡、Discover和用餐者俱樂部等。這種演算法最初是在20世紀60年代由一組數學家製定,現在Luhn檢驗數字演算法屬於大眾,任何人都可以使用它
假設現在有一個招行卡號6225882708965808
(國內一般的主流銀行卡號一般是16位或19位)
從最後一位開始逆向 計算奇數 位元相加總和
#如上面的卡號計算入下
8 + 8 + 6 + 8 + 7 + 8 + 5 + 2 = 52
逆向 將偶數 位元先乘2 如果乘積為
2位數 則減去9 在求和如果乘積不是
2位數 則直接相加
0 * 2 = 0 5 * 2 = 10 - 9 = 1 9 * 2 = 18 - 9 = 9 0 * 2 = 0 2 * 2 = 4 8 * 2 = 16 - 9 = 7 2 * 2 = 4 6 * 2 = 12 - 9 = 3 最后计算结果 0 + 1 + 9 + 0 + 4 + 7 + 4 + 3 = 28
52 + 28 = 80 80 % 10 = 0
function checkLuhn($card){ $len=strlen($card); $all=[]; $sum_odd=0; $sum_even=0; for($i=0;$i<$len;$i++){ $all[]=substr($card,$len-$i-1,1); } //all 里的偶数key都是我们要相加的奇数位 for($k=0;$k<$len;$k++){ if($k % 2 ==0){ $sum_odd+=$all[$k]; }else{ //奇数key都是要相加的偶数和 if($all[$k] * 2 >= 10){ $sum_even+=$all[$k] * 2 - 9; }else{ $sum_even+=$all[$k]*2; } } } $total=$sum_odd+$sum_even; if($total % 10 == 0){ return true; }else{ return false; } }
有錯誤希望指出
當然在做這個之前需要做一些判斷的,能想到自己家吧。最後這個也並非100%適用所有的銀行卡號。推薦學習:《PHP影片教學》#
以上是總結PHP中銀行卡號通用校驗演算法的詳細內容。更多資訊請關注PHP中文網其他相關文章!