银行卡号码的校验规则
前言
我們公司業(yè)務判斷身份證號和銀行卡號是否符合時,居然直接調(diào)接口驗證,甚至本地的開發(fā)環(huán)境沒有做校驗,測試環(huán)境卻連接到新加坡總部的服務器驗證,這一系列的騷操作是如此辣眼睛,ε=(´ο`*)))唉~
于是好心幫公司把前端的校驗寫了,因為在前端如果格式就正確,此時再調(diào)用后臺接口驗證,可以一定概率的避免因客戶手誤輸錯卡號而進行的接口重復調(diào)用,從而盡可能的減少服務器的壓力。
銀行卡號碼的校驗采用LUHN算法(模10算法),校驗如下:
1.拿出卡號最后一位的校驗位后,從右至左,將卡號按位編碼,從0開始,判斷偶數(shù)或奇數(shù)
2.判斷邏輯--對每一位的計算規(guī)則:如果這一位是奇數(shù)位,則返回值本身,如果是偶數(shù)位,先將值乘以2得到一個數(shù)n,如果n是一位數(shù)(小于10),直接返回n,否則將n的個位數(shù)和十位數(shù)相加返回。
3.從右向左遍歷,對每一位字符執(zhí)行上面的判斷邏輯,并將每一位的計算結果相加得到一個總數(shù)sum。
4.如果sum+校驗位能夠整除10,則此號碼有效,否則號碼無效。
function verifyBankCard(num) {
num = num.toString().split('');//變?yōu)樽址俎D數(shù)組
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();//變?yōu)閿?shù)組再顛倒
let sum = 0;//總數(shù)
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));
總結
身份證校驗規(guī)則:https://www.cnblogs.com/zxd66666/p/13246137.html
總結
以上是生活随笔為你收集整理的银行卡号码的校验规则的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 用python爬网站评论_python爬
- 下一篇: 研究内容、研究方法、研究方案的区别与联系