Luhn算法计算银联卡卡号校验位
来源:互联网 发布:中国网络通信有限公司 编辑:程序博客网 时间:2024/05/21 22:21
银联卡卡号由三部分组成:发卡机构标识码(bin)、发卡机构自定义位、校验码。其中,卡号左起前六位是发卡机构标识代码(BIN),由6位数字组成。BIN号由中国银联复制分配、确认和管理;卡号第七位起事发卡机构自定义位,由6至12位数字组成,发卡机构自行赋值;卡号最后一位是校验码,根据校验位前的数字(含BIN)取值Luhn方程计算得出。
Luhn计算模10 “隔位2倍加”校验数的公式 计算步骤如下:1、从右边第一个数字(低序)开始每隔一位乘以2。2、把在步骤1中获得的乘积的各位数字与原号码中位乘2的各位数字相加求和。3、从步骤2中获得的数字邻近的较高的以0结尾的数字减去该数字(即求这个总和的低位数字(个位数)的“10的补数”)。如果在步骤2中得到的总和是以0结尾的数,则校验数字就是0。 代码如下:
package com.cup.tracy;public class Luhn {/** * Luhn算法 * 根据卡号获取校验位 * @param cardNumber * @return */public static int getCheckNumber(String cardNumber){int totalNumber = 0;int lastNumber = 0;for (int i = cardNumber.length()-1; i >= 0; i-=2) {int tmpNumber = calculate(Integer.parseInt(String.valueOf(cardNumber.charAt(i))) * 2);if (i==0) {totalNumber += tmpNumber;}else {totalNumber += tmpNumber + Integer.parseInt(String.valueOf(cardNumber.charAt(i-1)));}}if (totalNumber >= 0 && totalNumber < 9) {return (10 - totalNumber);}else {String str = String.valueOf(totalNumber);if (Integer.parseInt(String.valueOf(str.charAt(str.length()-1))) == 0) {return 0; }else {return (10 - Integer.parseInt(String.valueOf(str.charAt(str.length()-1))));}}}/** * 计算数字各位和 * @param number * @return */public static int calculate(int number){String str = String.valueOf(number);int total = 0;for (int i = 0; i < str.length(); i++) {total += Integer.valueOf(Integer.parseInt(String.valueOf(str.charAt(i))));}return total;}public static void main(String[] args) {String cardNumber = "4992739871";System.out.println(getCheckNumber(cardNumber));}}
- Luhn算法计算银联卡卡号校验位
- 信用卡校验位算法THE LUHN MOD-10
- luhn计算最后一位校验位(ICCID,银行卡号)
- 银行卡号校验位的LUHN算法模10“隔位2倍加”校验数的公式
- 计算MEID校验位的算法函数
- 计算IMEI校验位的算法函数
- Luhn算法
- Luhn 算法
- 计算EAN-13校验位
- IMEI/MEID校验位计算
- IMEI/MEID校验位计算
- 算法系列4《Luhn》
- EAN13码校验位算法
- MEID校验位算法
- 新版身份证校验位算法
- python实现身份证校验位计算
- python实现身份证校验位计算
- 计算IMEI号的校验位
- 连接数据库的步骤
- 基于Linux的新移动操作系统泰泽
- Oracle触发器(Trigger)与序列(Sequences)
- adb常用命令
- 新手学习数据结构与算法---链表多项式
- Luhn算法计算银联卡卡号校验位
- 使用.netrc文件进行自动ftp
- VC重载PreTranslateMessage事件实现鼠标双击
- set_irq_type 引发的 irq函数的变更
- HTTP协议
- inline内联函数的引入
- 对hadoop 执行mapreduce时发生异常Illegal partition for的解决过程
- 【转】]mysql_fetch_row, mysql_fetch_array, mysql_fetch_assoc的区别和不同
- 选择排序