1. 国内的银行卡号是一串根据Luhm校验算法计算出来的数字,Luhm校验规则:16位银行卡号(19位通用)
1.将未带校验位的 15(或18)位卡号从右依次编号 1 到 15(18),位于奇数位号上的数字乘以 2。
2.将奇位乘积的个十位全部相加,再加上所有偶数位上的数字。
3.将加法和加上校验位能被 10 整除。
2. js实现
var cno = '6212288802000001666';
var arr = cno.split(/(\d)$/); // ["621228880200000166", "6", ""]
var preTotal = arr[0].split('')
.reverse()
.map(function (x, idx) {
return (idx + 1) % 2 == 0 ? x * 1 : x * 2 ;
})
.map(function (x) {
return x >= 10 ? x - 9 : x;
})
.reduce(function (x, y) {
return x + y;
});
var total = arr[1] * 1 + preTotal;
var isValid = total % 10 == 0;
console.log(isValid);
本文介绍了一种用于校验银行卡号有效性的Luhn算法,并通过JavaScript代码实现了该算法的具体应用过程。Luhn算法通过对银行卡号进行特定的数学运算来验证其合法性。
1万+

被折叠的 条评论
为什么被折叠?



