时间:2021-07-01 10:21:17 帮助过:6人阅读
这篇文章主要介绍了PHP实现通过Luhn算法校验信用卡卡号是否有效,实例分析了php实现Luhn算法及相关应用技巧,具有一定参考借鉴价值,需要的朋友可以参考下
本文实例讲述了PHP实现通过Luhn算法校验信用卡卡号是否有效的方法。分享给大家供大家参考。具体实现方法如下:
?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
$numbers = "49927398716 49927398717 1234567812345678 1234567812345670"; foreach (split(' ', $numbers) as $n) echo "$n is ", luhnTest($n) ? 'valid' : 'not valid', '';
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; } |
运行结果
?
1 2 3 4 |
49927398716 is valid 49927398717 is not valid 1234567812345678 is not valid 1234567812345670 is valid |
下面是一个更为简洁的代码:
代码如下:
function luhn_test($num) {
输出结果如下
?
1 2 3 4 |
49927398716 is valid 49927398717 is not valid 1234567812345678 is not valid 1234567812345670 is valid |
希望本文所述对大家的php程序设计有所帮助。
http://www.bkjia.com/PHPjc/973138.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/973138.htmlTechArticlePHP实现通过Luhn算法校验信用卡卡号是否有效 这篇文章主要介绍了PHP实现通过Luhn算法校验信用卡卡号是否有效,实例分析了php实现Luhn算法及...