您好,登錄后才能下訂單哦!
這篇文章主要講解了“PHP中銀行卡號通用校驗算法介紹”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“PHP中銀行卡號通用校驗算法介紹”吧!
最近因公司需求寫了點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
將奇數位總和加上偶數位總和 如果結果可以被10整除則表示驗證通過
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中銀行卡號通用校驗算法介紹這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。