JavaScript實現LUHN算法驗證銀行卡號有效性


一般驗證銀行卡有效性用到一種叫做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 }

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM