前言

  我们公司业务判断身份证号和银行卡号是否符合时,居然直接调接口验证,甚至本地的开发环境没有做校验,测试环境却连接到新加坡总部的服务器验证,这一系列的骚操作是如此辣眼睛,ε=(´ο`*)))唉~

  于是好心帮公司把前端的校验写了,因为在前端如果格式就正确,此时再调用后台接口验证,可以一定概率的避免因客户手误输错卡号而进行的接口重复调用,从而尽可能的减少服务器的压力。

银行卡号码的校验采用LUHN算法(模10算法),校验如下:
  1. 拿出卡号最后一位的校验位后,从右至左,将卡号按位编码,从0开始,判断偶数或奇数
  2. 判断逻辑–对每一位的计算规则:如果这一位是奇数位,则返回值本身,如果是偶数位,先将值乘以2得到一个数n,如果n是一位数(小于10),直接返回n,否则将n的个位数和十位数相加返回。
  3. 从右向左遍历,对每一位字符执行上面的判断逻辑,并将每一位的计算结果相加得到一个总数sum。
  4. 如果sum+校验位能够整除10,则此号码有效,否则号码无效。

function verifyBankCard(num) {
  num = num.toString().split('');//变为字符串再转数组
  if(num.length > 19 || num.length < 15) return false;//银行卡号长度为15-19
  let lastNum = parseInt(num[num.length-1]);//取出最后一位--校验位
  num.length = num.length - 1;//删除最后一个值
  num = num.reverse();//变为数组再颠倒

  let sum = 0;//总数
  num.forEach((elem,i) => {
    elem = parseInt(elem);
    if(i % 2 === 0) {
      let n = elem * 2;
      if(n < 10) sum += n;
      else sum += (parseInt(n/10) + n%10);
    }
    else sum += elem;
  });
  return (sum+lastNum) % 10 === 0 ? true : false;
}

// let cardNumber = 6226094425653290;//true
// let cardNumber = 6226097143099498;//true
// let cardNumber = 6226097143099497;//false
let cardNumber = 62260971430994971234;//false
console.log("最终结果:",verifyBankCard(cardNumber));

总结

  身份证校验规则https://www.cnblogs.com/zxd66666/p/13246137.html