您好,欢迎访问一九零五行业门户网

PHP实现通过Luhn算法校验信用卡卡号是否有效_PHP教程

php实现通过luhn算法校验信用卡卡号是否有效 这篇文章主要介绍了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) {
$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', \n; 
输出结果如下
?
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算法及...
其它类似信息

推荐信息