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;
    }
     
  • 相关阅读:
    LeetCode
    LeetCode
    一篇真正教会你开发移动端页面的文章(一)
    移动端页面开发资源总结
    Vue 模板
    使用 concurrently 并行地运行多个命令(同时跑前端和后端的服务)
    值得H5前端学习的60个JS插件(含DEMO演示)
    解读浮动闭合最佳方案:clearfix
    JavaScript 如何工作的: 事件循环和异步编程的崛起 + 5 个关于如何使用 async/await 编写更好的技巧
    JavaScript 运行机制详解:再谈Event Loop
  • 原文地址:https://www.cnblogs.com/yangmx/p/3965811.html
Copyright © 2011-2022 走看看