一般驗證銀行卡有效性用到一種叫做LUHN的算法,簡介請參考這篇博客:基於Luhn算法的銀行卡卡號的格式校驗
注意:
1、LUHN算法只是能校驗卡號是否有效,並不能校驗卡號和用戶名是否一致。
2、如果有部分銀行卡不符合LUHN算法的話,也不用奇怪,有這種可能。
下面貼出JS實現的LUHN算法:
1 /** 2 * 檢查銀行卡號是否符合規則 3 * @param bankno 銀行卡號 4 * @returns 5 */ 6 function checkBankNo(bankno) { 7 var bankno = bankno.replace(/\s/g, ''); 8 if (bankno == "") { 9 alert("請填寫銀行卡號"); 10 return false; 11 } 12 if (bankno.length < 16 || bankno.length > 19) { 13 alert("銀行卡號長度必須在16到19之間"); 14 return false; 15 } 16 var num = /^\d*$/;// 全數字 17 if (!num.exec(bankno)) { 18 alert("銀行卡號必須全為數字"); 19 return false; 20 } 21 // 開頭兩位 22 var strBin = "10,18,30,35,37,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,58,60,62,65,68,69,84,87,88,94,95,98,99"; 23 if (strBin.indexOf(bankno.substring(0, 2)) == -1) { 24 alert("銀行卡號開頭兩位不符合規范"); 25 return false; 26 } 27 // luhn校驗 28 if (!luhnCheck(bankno)) { 29 return false; 30 } 31 return true; 32 } 33 34 /** 35 * 銀行卡號luhn校驗算法 36 * luhn校驗規則:16位銀行卡號(19位通用): 37 * 1.將未帶校驗位的 15(或18)位卡號從右依次編號 1 到 15(18),位於奇數位號上的數字乘以 2。 38 * 2.將奇位乘積的個十位全部相加,再加上所有偶數位上的數字。 39 * 3.將加法和加上校驗位能被 10 整除。 40 * @param bankno 銀行卡號 41 * @returns 42 */ 43 function luhnCheck(bankno) { 44 var lastNum = bankno.substr(bankno.length - 1, 1);// 取出最后一位(與luhn進行比較) 45 var first15Num = bankno.substr(0, bankno.length - 1);// 前15或18位 46 var newArr = new Array(); 47 for (var i = first15Num.length - 1; i > -1; i--) { // 前15或18位倒序存進數組 48 newArr.push(first15Num.substr(i, 1)); 49 } 50 var arrJiShu = new Array(); // 奇數位*2的積 <9 51 var arrJiShu2 = new Array(); // 奇數位*2的積 >9 52 var arrOuShu = new Array(); // 偶數位數組 53 for (var j = 0; j < newArr.length; j++) { 54 if ((j + 1) % 2 == 1) {// 奇數位 55 if (parseInt(newArr[j]) * 2 < 9) { 56 arrJiShu.push(parseInt(newArr[j]) * 2); 57 } else { 58 arrJiShu2.push(parseInt(newArr[j]) * 2); 59 } 60 } else { 61 arrOuShu.push(newArr[j]);// 偶數位 62 } 63 } 64 65 var jishu_child1 = new Array();// 奇數位*2 >9 的分割之后的數組個位數 66 var jishu_child2 = new Array();// 奇數位*2 >9 的分割之后的數組十位數 67 for (var h = 0; h < arrJiShu2.length; h++) { 68 jishu_child1.push(parseInt(arrJiShu2[h]) % 10); 69 jishu_child2.push(parseInt(arrJiShu2[h]) / 10); 70 } 71 var sumJiShu = 0; // 奇數位*2 < 9 的數組之和 72 var sumOuShu = 0; // 偶數位數組之和 73 var sumJiShuChild1 = 0; // 奇數位*2 >9 的分割之后的數組個位數之和 74 var sumJiShuChild2 = 0; // 奇數位*2 >9 的分割之后的數組十位數之和 75 var sumTotal = 0; 76 for (var m = 0; m < arrJiShu.length; m++) { 77 sumJiShu = sumJiShu + parseInt(arrJiShu[m]); 78 } 79 for (var n = 0; n < arrOuShu.length; n++) { 80 sumOuShu = sumOuShu + parseInt(arrOuShu[n]); 81 } 82 for (var p = 0; p < jishu_child1.length; p++) { 83 sumJiShuChild1 = sumJiShuChild1 + parseInt(jishu_child1[p]); 84 sumJiShuChild2 = sumJiShuChild2 + parseInt(jishu_child2[p]); 85 } 86 // 計算總和 87 sumTotal = parseInt(sumJiShu) + parseInt(sumOuShu) 88 + parseInt(sumJiShuChild1) + parseInt(sumJiShuChild2); 89 // 計算luhn值 90 var k = parseInt(sumTotal) % 10 == 0 ? 10 : parseInt(sumTotal) % 10; 91 var luhn = 10 - k; 92 if (lastNum == luhn) { 93 console.log("驗證通過"); 94 return true; 95 } else { 96 alert("銀行卡號必須符合luhn校驗"); 97 return false; 98 } 99 }
再貼一個JAVA實現的LUHN算法:
1 /** 2 * 匹配luhn算法:可用於檢測銀行卡卡號 3 * @param cardNo 4 * @return 5 */ 6 public static boolean matchLuhn(String cardNo) { 7 int[] cardNoArr = new int[cardNo.length()]; 8 for (int i=0; i<cardNo.length(); i++) { 9 cardNoArr[i] = Integer.valueOf(String.valueOf(cardNo.charAt(i))); 10 } 11 for(int i=cardNoArr.length-2;i>=0;i-=2) { 12 cardNoArr[i] <<= 1; 13 cardNoArr[i] = cardNoArr[i]/10 + cardNoArr[i]%10; 14 } 15 int sum = 0; 16 for(int i=0;i<cardNoArr.length;i++) { 17 sum += cardNoArr[i]; 18 } 19 return sum % 10 == 0; 20 }