java - 使用 Luhn 算法检查信用卡有效性

标签 java arrays validation credit-card luhn

我尝试使用 Luhn 算法检查信用卡的有效性,其工作步骤如下:

  1. 从右到左每隔两个数字加倍。如果将一位数字加倍得到两位数,则将这两位数相加得到一位数。

    2 * 2 = 4

    2 * 2 = 4

    4 * 2 = 8

    1 * 2 = 2

    6 * 2 = 12(1 + 2 = 3)

    5 * 2 = 10(1 + 0 = 1)

    8 * 2 = 16(1 + 6 = 7)

    4 * 2 = 8

  2. 现在将第 1 步中的所有个位数相加。

    4 + 4 + 8 + 2 + 3 + 1 + 7 + 8 = 37

  3. 将卡号中奇数位的所有数字从右到左相加。

    6 + 6 + 0 + 8 + 0 + 7 + 8 + 3 = 38

  4. 将第 2 步和第 3 步的结果相加。

    37 + 38 = 75

  5. 如果第 4 步的结果能被 10 整除,则卡号有效;否则无效。例如,号码4388576018402626无效,但号码4388576018410707有效。

简单地说,我的程序总是对我输入的所有内容显示有效。即使它是一个有效数字并且 sumOfOddPlace 和 sumOfDoubleEvenPlace 方法的结果等于零。
感谢任何帮助。

import java.util.Scanner;
public class CreditCardValidation {
      public static void main(String[] args) {
     Scanner in = new Scanner(System.in);
        int count = 0;
        long array[] = new long [16];
       do
       {
        count = 0;
       array = new long [16];
        System.out.print("Enter your Credit Card Number : ");
        long number = in.nextLong();
        for (int i = 0; number != 0; i++) {
        array[i] = number % 10;
        number = number / 10;
        count++;
        }
       }
        while(count < 13); 
        if ((array[count - 1] == 4) || (array[count - 1] == 5) || (array[count - 1] == 3 && array[count - 2] == 7)){
            if (isValid(array) == true) {
                System.out.println("\n The Credit Card Number is Valid. ");
        } else {
            System.out.println("\n The Credit Card Number is Invalid. ");
        }
        } else{
          System.out.println("\n The Credit Card Number is Invalid. ");
        }
    }

    public static boolean isValid(long[] array) {
        int total = sumOfDoubleEvenPlace(array) + sumOfOddPlace(array);        
        if ((total % 10 == 0)) {
         for (int i=0; i< array.length; i++){
            System.out.println(array[i]);}
            return true;
        } else {
          for (int i=0; i< array.length; i++){
            System.out.println(array[i]);}
            return false;
        }
    }

    public static int getDigit(int number) {
        if (number <= 9) {
            return number;
        } else {
            int firstDigit = number % 10;
            int secondDigit = (int) (number / 10);
            return firstDigit + secondDigit;
        }
    }

    public static int sumOfOddPlace(long[] array) {
        int result = 0;
        for (int i=0; i< array.length; i++)
        {
        while (array[i] > 0) {
            result += (int) (array[i] % 10);
            array[i] = array[i] / 100;
         }}
         System.out.println("\n The sum of odd place is " + result);
        return result;
    }

    public static int sumOfDoubleEvenPlace(long[] array) {
        int result = 0;
        long temp = 0;
        for (int i=0; i< array.length; i++){
        while (array[i] > 0) {
             temp = array[i] % 100;
             result += getDigit((int) (temp / 10) * 2);
            array[i] = array[i] / 100;
           }
        }
        System.out.println("\n The sum of double even place is " + result);
        return result;
    }
     }

最佳答案

您可以随意导入以下代码:

public class Luhn
{
    public static boolean Check(String ccNumber)
    {
            int sum = 0;
            boolean alternate = false;
            for (int i = ccNumber.length() - 1; i >= 0; i--)
            {
                    int n = Integer.parseInt(ccNumber.substring(i, i + 1));
                    if (alternate)
                    {
                            n *= 2;
                            if (n > 9)
                            {
                                    n = (n % 10) + 1;
                            }
                    }
                    sum += n;
                    alternate = !alternate;
            }
            return (sum % 10 == 0);
    }
}

链接引用:https://github.com/jduke32/gnuc-credit-card-checker/blob/master/CCCheckerPro/src/com/gnuc/java/ccc/Luhn.java

关于java - 使用 Luhn 算法检查信用卡有效性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20725761/

相关文章:

java - 如何找到字符串中最高的字母?

使用数组进行 javascript 验证

java - 我需要在cmd中为基于文本的游戏播放声音

java - 有没有比 Libgdx 更好的 2D 游戏引擎?

python - 如何在Python中将数组与其数组元素合并?

java - 手机号码字段验证

c# - 使用存储库数据库的 WCF 自定义用户名和密码验证程序#

java - 将文本数据存储在一个/多个文件中以使其可用于各种平台的最佳方法是什么?

java - 休息| @生产和@消费: why dont they both get called for same MIME-type

c - Ansi C:高流量控制/仅用*星号替换第一次出现的内容,并删除每个重复项