如何在文本字符串中验证卡PAN?

时间:2018-05-17 07:27:27

标签: java luhn

我有任何文字的字符串。它可以是这样的 - "abcdef 123456789521 zxcvb", - "45651256"和 - "asdad 564654 sddsf 4"。我想在文本PAN号中搜索,这可能是不同的长度,而不是用luhn算法验证它。我知道,我可以通过regx找到它,但它需要这样的表达 - "Pattern.compile("[A-Z]{5}[0-9]{4}[A-Z]{1}");。但是我不知道我的字符串将包含多少个字符和数字以及它们的顺序。可能有人知道怎么做吗?有什么建议吗?

1 个答案:

答案 0 :(得分:2)

我认为PAN是指信用卡号(see PAN on wikipedia)。

根据那篇文章,数字必须在8到19位之间。因此,您在文本中搜索具有该间隔长度的数字,存储它们并使用Luhn algorithm进行检查。这是一个实现,它可以找到长度在8到19位之间的数字并执行Luhn检查:

pip install dbus-python
import java.util.ArrayList;
import java.util.regex.Pattern;    
import java.util.regex.Matcher;

public class main {
    public static void main(String[] args) {
        String text = "helloWor4712389062l648977135536d 239012390oife234923 uiwed wq12893129038";

        ArrayList<String> result = getPossiblePANs(text);
        for(String pan : result) {
            System.out.print("Possible PAN: " + pan);
            if(luhnCheck(pan))
                System.out.println(" is valid!");
            else
                System.out.println(" is INVALID!");
        }
    }


    static ArrayList<String> getPossiblePANs(String text){  //Numbers w. 8-19 digits
        ArrayList<String> res = new ArrayList<>();
        Pattern p = Pattern.compile("\\d{8,19}+");
        Matcher m = p.matcher(text);
        while(m.find())
            res.add(m.group());
        return res;
    }

    static boolean luhnCheck(String cardNumber){
        if(cardNumber.length() < 8 || cardNumber.length() > 19)
            return false;
        int sum = 0;
        int begin = cardNumber.length() - 2;
        for(int i = begin; i >= 0; i-=2){
            int number = Integer.parseInt(cardNumber.substring(i, i+1)) * 2;
            if(number > 9) sum += (number - 9);
            else sum += number;
        }
        return (sum % 10) == 0;
    }
}
相关问题