這篇文章主要介紹了PHP實現通過Luhn演算法校正信用卡卡號是否有效,執行個體分析了php實現Luhn演算法及相關應用技巧,具有一定參考借鑒價值,需要的朋友可以參考下
本文執行個體講述了PHP實現通過Luhn演算法校正信用卡卡號是否有效方法。具體實現方法如下:
$numbers = "49927398716 49927398717 1234567812345678 1234567812345670";foreach (split(' ', $numbers) as $n) echo "$n is ", luhnTest($n) ? 'valid' : 'not valid', '</br>'; function luhnTest($num) { $len = strlen($num); for ($i = $len-1; $i >= 0; $i--) { $ord = ord($num[$i]); if (($len - 1) & $i) { $sum += $ord; } else { $sum += $ord / 5 + (2 * $ord) % 10; } } return $sum % 10 == 0;}
運行結果
49927398716 is valid49927398717 is not valid1234567812345678 is not valid1234567812345670 is valid
下面是一個更為簡潔的代碼:
代碼如下:
function luhn_test($num) { $str = ''; foreach( array_reverse( str_split( $num ) ) as $i => $c ) $str .= ($i % 2 ? $c * 2 : $c ); return array_sum( str_split($str) ) % 10 == 0;}foreach (array('49927398716','49927398717','1234567812345678','1234567812345670') as $n)echo "$n is ", luhn_test($n) ? 'valid' : 'not valid', "</br>\n";
輸出結果如下
49927398716 is valid49927398717 is not valid1234567812345678 is not valid1234567812345670 is valid
總結:以上就是本篇文的全部內容,希望能對大家的學習有所協助。