zoukankan      html  css  js  c++  java
  • 效验是否为银行卡

    http://www.oschina.net/code/snippet_86738_3128

    效验是否为银行卡,用于验证 
    现行 16 位银联卡现行卡号开头 6 位是 622126~622925 之间的,7 到 15 位是银行自定义的, 
    可能是发卡分行,发卡网点,发卡序号,第 16 位是校验码。 

    16 位卡号校验位采用 Luhm 校验方法计算: 

    1,将未带校验位的 15 位卡号从右依次编号 1 到 15,位于奇数位号上的数字乘以 2 
    2,将奇位乘积的个十位全部相加,再加上所有偶数位上的数字 
    3,将加法和加上校验位能被 10 整除。 

       6  2  2  5   8  8  1  4   1  4  2  0   7  4  3
    *  2     2      2     2      2     2      2     2
    --------------------------------------------------
      12  2  4  5  16  8  2  4   2  4  4     14  4  6
    
    将上面的数字加和:1+2+2+4+5+1+6+8+2+4+2+4+4+1+4+4+6 = 60
    
    由于 60 加上 0 才能被 10 整除,所以校验位为 0
    
    因此该卡号为 6225 8814 1420 7430

    如果其中一位数字换掉的话,直接导致最后校验位错误。
     
    标签: 银行卡
    public class Test {
     
        public static void main(String[] args) {
            String card = "6227007200120897790";
            System.out.println("      card: " + card);
            System.out.println("check code: " + getBankCardCheckCode(card));
            System.out.println("是否为银行卡:"+checkBankCard(card));
        }
        
        /**
         * 校验银行卡卡号
         * @param cardId
         * @return
         */
        public static boolean checkBankCard(String cardId) {
                 char bit = getBankCardCheckCode(cardId.substring(0, cardId.length() - 1));
                 if(bit == 'N'){
                     return false;
                 }
                 return cardId.charAt(cardId.length() - 1) == bit;
        }
        
        /**
         * 从不含校验位的银行卡卡号采用 Luhm 校验算法获得校验位
         * @param nonCheckCodeCardId
         * @return
         */
        public static char getBankCardCheckCode(String nonCheckCodeCardId){
            if(nonCheckCodeCardId == null || nonCheckCodeCardId.trim().length() == 0
                    || !nonCheckCodeCardId.matches("\d+")) {
                //如果传的不是数据返回N
                return 'N';
            }
            char[] chs = nonCheckCodeCardId.trim().toCharArray();
            int luhmSum = 0;
            for(int i = chs.length - 1, j = 0; i >= 0; i--, j++) {
                int k = chs[i] - '0';
                if(j % 2 == 0) {
                    k *= 2;
                    k = k / 10 + k % 10;
                }
                luhmSum += k;           
            }
            return (luhmSum % 10 == 0) ? '0' : (char)((10 - luhmSum % 10) + '0');
        }
    }
    OC:
    /**
     * 校验银行卡卡号
     * @param cardId
     * @return
     */
    BOOL checkCardNo(NSString* cardNo){
        if ((int)cardNo.length < 13 || (int)cardNo.length > 19) return NO;
        NSString *str = [cardNo substringWithRange:NSMakeRange(0, cardNo.length - 1)];
        int luhmSum = 0;
        for(int i = (int)str.length - 1, j = 0; i >= 0; i--, j++) {
            int k = [str characterAtIndex:i] - '0';
            if(j % 2 == 0) {
                k *= 2;
                k = k / 10 + k % 10;
            }
            luhmSum += k;
        }
        char bit = (luhmSum % 10 == 0) ? '0' : (char)((10 - luhmSum % 10) + '0');
        if(bit == 'N'){
            return false;
        }
        return [cardNo characterAtIndex:cardNo.length - 1] == bit;
    }
     
  • 相关阅读:
    方法:常用SQL时间格式
    讨论:C#Calendar赋初始值
    解释:C++虚函数
    方法:C#用session做登陆
    方法:C#在WinForm中如何将Image存入SQL2000和取出显示
    从请求管道深入剖析HttpModule的实现机制,有图有真相
    偶然在网上看到的题目,jQuery功底如何一测便知晓!!!!!!
    MVC2.0中的HtmlHelper大全
    九度 题目1500:出操队形
    九度 题目1528:最长回文子串
  • 原文地址:https://www.cnblogs.com/yangmx/p/3965811.html
Copyright © 2011-2022 走看看