LUHN算法,主要用来计算信用卡等证件号码的合法性。
1、从卡号最后一位数字开始,偶数位乘以2,如果乘以2的结果是两位数,将两个位上数字相加保存。
2、把所有数字相加,得到总和。
3、如果信用卡号码是合法的,总和可以被10整除。
/**
* 验证是否为银行卡号 使用luhn 方法验证
*/
public static boolean isBankNumber(String bankNumber) {
char[] cc = bankNumber.toCharArray();
int[] n = new int[cc.length + 1];
int j = 1;
for (int i = cc.length - 1; i >= 0; i--) {
n[j++] = cc[i] - '0';
}
int even = 0;
int odd = 0;
for (int i = 1; i < n.length; i++) {
if (i % 2 == 0) {
int temp = n[i] * 2;
if (temp < 10) {
even += temp;
} else {
temp = temp - 9;
even += temp;
}
} else {
odd += n[i];
}
}
int total = even + odd;
if (total % 10 == 0)
return true;
return false;
}