JavaScript 银行卡的正则表达式验证

🌙
手机阅读
本文目录结构

下面是正则表达式的验证;

别人分享的;需要手动写一套 substr 函数

/**
 *Luhn校验算法校验银行卡号
 *Description:  银行卡号Luhm校验
 *Luhm校验规则:16位银行卡号(19位通用):
 *1.将未带校验位的 15(或18)位卡号从右依次编号 1 到 15(18),位于奇数位号上的数字乘以 2。
 *2.将奇位乘积的个十位全部相加,再加上所有偶数位上的数字。
 *3.将加法和加上校验位能被 10 整除。
 *方法步骤很清晰,易理解,需要在页面引用Jquery.js
 *bankno为银行卡号
 */
function luhmCheck(bankno) {
var lastNum = bankno.substr(bankno.length - 1, 1);//取出最后一位(与luhm进行比较)
    var first15Num = bankno.substr(0, bankno.length - 1);//前15或18位
    var newArr = new Array();
for (var i = first15Num.length - 1; i > -1; i--) {//前15或18位倒序存进数组
        newArr.push(first15Num.substr(i, 1));
    }
var arrJiShu = new Array();  //奇数位*2的积 <9
    var arrJiShu2 = new Array(); //奇数位*2的积 >9
    var arrOuShu = new Array();  //偶数位数组
    for (var j = 0; j < newArr.length; j++) {
if ((j + 1) % 2 == 1) {//奇数位
            if (parseInt(newArr[j]) * 2 < 9)
arrJiShu.push(parseInt(newArr[j]) * 2);
else
                arrJiShu2.push(parseInt(newArr[j]) * 2);
        }
else //偶数位
            arrOuShu.push(newArr[j]);
    }

var jishu_child1 = new Array();//奇数位*2 >9 的分割之后的数组个位数
    var jishu_child2 = new Array();//奇数位*2 >9 的分割之后的数组十位数
    for (var h = 0; h < arrJiShu2.length; h++) {
jishu_child1.push(parseInt(arrJiShu2[h]) % 10);
jishu_child2.push(parseInt(arrJiShu2[h]) / 10);
    }

var sumJiShu = 0; //奇数位*2 < 9 的数组之和
    var sumOuShu = 0; //偶数位数组之和
    var sumJiShuChild1 = 0; //奇数位*2 >9 的分割之后的数组个位数之和
    var sumJiShuChild2 = 0; //奇数位*2 >9 的分割之后的数组十位数之和
    var sumTotal = 0;
for (var m = 0; m < arrJiShu.length; m++) {
sumJiShu = sumJiShu + parseInt(arrJiShu[m]);
    }

for (var n = 0; n < arrOuShu.length; n++) {
sumOuShu = sumOuShu + parseInt(arrOuShu[n]);
    }

for (var p = 0; p < jishu_child1.length; p++) {
sumJiShuChild1 = sumJiShuChild1 + parseInt(jishu_child1[p]);
sumJiShuChild2 = sumJiShuChild2 + parseInt(jishu_child2[p]);
    }
//计算总和
    sumTotal = parseInt(sumJiShu) + parseInt(sumOuShu) + parseInt(sumJiShuChild1) + parseInt(sumJiShuChild2);

//计算Luhm值
    var k = parseInt(sumTotal) % 10 == 0 ? 10 : parseInt(sumTotal) % 10;
var luhm = 10 - k;
var my = false;
if (lastNum == luhm) {//Luhm验证通过
        my = true;
    }
else {//银行卡号必须符合Luhm校验
        my = false;
    }
return my;
}

luhmCheck(123456);

AXIHE / 精选资源

浏览全部教程

面试题

学习网站

前端培训
自己甄别

前端书籍

关于朱安邦

我叫 朱安邦,阿西河的站长,在杭州。

以前是一名平面设计师,后来开始接接触前端开发,主要研究前端技术中的JS方向。

业余时间我喜欢分享和交流自己的技术,欢迎大家关注我的 Bilibili

关注我: Github / 知乎

目前重心已经放在研究区块链上面了

我叫朱安邦,阿西河的站长

目前在杭州从事区块链周边的开发工作,机械专业,以前从事平面设计工作。

2014年底脱产在老家自学6个月的前端技术,自学期间几乎从未出过家门,最终找到了满意的前端工作。更多>