银行卡号Luhm校验Java实现代码
import java.util.regex.Matcher;
import java.util.regex.Pattern;
public class CheckBankNumber {
//Description: 银行卡号Luhm校验
//Luhm校验规则:16位银行卡号(19位通用):
// 1.将未带校验位的 15(或18)位卡号从右依次编号 1 到 15(18),位于奇数位号上的数字乘以 2。
// 2.将奇位乘积的个十位全部相加,再加上所有偶数位上的数字。
// 3.将加法和加上校验位能被 10 整除。
//开头6位
//private final static String strBin = "10,18,30,35,37,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,58,60,62,65,68,69,84,87,88,94,95,98,99";
private final static String SUCCESS="true";
private final static String BAD_LENGTH="银行卡号长度必须在16到19之间";
private final static String NOT_NUMBER="银行卡必须全部为数字";
private final static String ILLEGAL_NUMBER="银行卡不符合规则";
public static String luhmCheck(String bankno){
if (bankno.length() < 16 || bankno.length() > 19) {
return BAD_LENGTH;
}
Pattern pattern = Pattern.compile("[0-9]*");
Matcher match = pattern.matcher(bankno);
if (match.matches() == false) {
return NOT_NUMBER;
}
// if (strBin.indexOf(bankno.substring(0, 2)) == -1) {
// return "银行卡号开头6位不符合规范";
// }
int lastNum=Integer.parseInt(bankno.substring(bankno.length()-1,bankno.length()));//取出最后一位(与luhm进行比较)
String first15Num=bankno.substring(0,bankno.length()-1);//前15或18位
//System.out.println(first15Num);
char[] newArr = new char[first15Num.length()]; //倒叙装入newArr
char[] tempArr = first15Num.toCharArray();
for(int i = 0; i < tempArr.length ; i++){
newArr[tempArr.length-1-i] = tempArr[i];
}
//System.out.println(newArr);
int[] arrSingleNum = new int[newArr.length]; //奇数位*2的积 <9
int[] arrSingleNum2 = new int[newArr.length];//奇数位*2的积 >9
int[] arrDoubleNum=new int[newArr.length]; //偶数位数组
for(int j = 0;j < newArr.length; j++){
if((j+1)%2==1){//奇数位
if((int)(newArr[j]-48)*2<9)
arrSingleNum[j]=(int)(newArr[j]-48)*2;
else
arrSingleNum2[j]=(int)(newArr[j]-48)*2;
}
else //偶数位
arrDoubleNum[j]=(int)(newArr[j]-48);
}
int[] arrSingleNumChild = new int[newArr.length]; //奇数位*2 >9 的分割之后的数组个位数
int[] arrSingleNum2Child = new int[newArr.length];//奇数位*2 >9 的分割之后的数组十位数
for(int h=0;h<arrSingleNum2.length;h++){
arrSingleNumChild[h] = (arrSingleNum2[h])%10;
arrSingleNum2Child[h] = (arrSingleNum2[h])/10;
}
int sumSingleNum=0; //奇数位*2 < 9 的数组之和
int sumDoubleNum=0; //偶数位数组之和
int sumSingleNumChild=0; //奇数位*2 >9 的分割之后的数组个位数之和
int sumSingleNum2Child=0; //奇数位*2 >9 的分割之后的数组十位数之和
int sumTotal=0;
for(int m=0;m<arrSingleNum.length;m++){
sumSingleNum=sumSingleNum+arrSingleNum[m];
}
for(int n=0;n<arrDoubleNum.length;n++){
sumDoubleNum=sumDoubleNum+arrDoubleNum[n];
}
for(int p=0;p<arrSingleNumChild.length;p++){
sumSingleNumChild=sumSingleNumChild+arrSingleNumChild[p];
sumSingleNum2Child=sumSingleNum2Child+arrSingleNum2Child[p];
}
sumTotal=sumSingleNum+sumDoubleNum+sumSingleNumChild+sumSingleNum2Child;
//计算Luhm值
int k= sumTotal%10==0?10:sumTotal%10;
int luhm= 10-k;
if(lastNum == luhm){
return SUCCESS;//验证通过
}
else{
return ILLEGAL_NUMBER;
}
}
public static void main(String[] args) {
String bankno = "6214857110432079";
System.out.println(bankno+":"+luhmCheck(bankno));
String bankno1 = "6212164000046323291";
System.out.println(bankno1+":"+luhmCheck(bankno1));
String bankno2 = "6222023104004123546";
System.out.println(bankno2+":"+luhmCheck(bankno2));
}
}
银行卡号Luhm校验Java实现代码的更多相关文章
- Regexp-Utils:银行卡号Luhm校验
ylbtech-Regexp-Utils:银行卡号Luhm校验 1.返回顶部 1.方法 //Description: 银行卡号Luhm校验 //Luhm校验规则:16位银行卡号(19位通用): // ...
- 银行卡luhm校验算法
/** * 15位银行卡luhm校验算法 * 1.从卡号最后一位数字开始,逆向将奇数位(1.3.5等等)相加. * 2.从卡号最后一位数字开始,逆向将偶数位数字,先乘以2(如果乘积为两位数,则将其减去 ...
- Java实现Luhm算法--银行卡号合法性校验
银行卡是由"发卡行标识代码 + 自定义 + 校验码 "等部分组成的. 银联标准卡与以往发行的银行卡最直接的区别就是其卡号前6位数字的不同. 银行卡卡号的前6位是用来表示发卡银行 ...
- pagebean pagetag java 后台代码实现分页 demo 前台标签分页 后台java分页
java 后台代码实现分页 demo 实力 自己写的 标签分页 package com.cszoc.sockstore.util; import java.util.HashMap;import ja ...
- 经典KMP算法C++与Java实现代码
前言: KMP算法是一种字符串匹配算法,由Knuth,Morris和Pratt同时发现(简称KMP算法).KMP算法的关键是利用匹配失败后的信息,尽量减少模式串与主串的匹配次数以达到快速匹配的目的.比 ...
- 常用 Java 静态代码分析工具的分析与比较
常用 Java 静态代码分析工具的分析与比较 简介: 本文首先介绍了静态代码分析的基 本概念及主要技术,随后分别介绍了现有 4 种主流 Java 静态代码分析工具 (Checkstyle,FindBu ...
- 分享:根据webservice WSDL地址自动生成java调用代码及JAR包
分享:根据webservice WSDL地址自动生成java调用代码及JAR包使用步骤:一.安装java 并配置JAVA_HOME 及 path二.安装ANT 并配置ANT_HOME三.解压WsdlT ...
- FastDFS搭建及java整合代码【转】
FastDFS软件介绍 1.什么是FastDFS FastDFS是用C语言编写的一款开源的分布式文件系统.FastDFS为互联网量身定制,充分考虑了冗余备份.负载均衡.线性扩容等机制,并注重高可用.高 ...
- [原创]Java静态代码检查工具介绍
[原创]Java静态代码检查工具介绍 一 什么是静态代码检查? 静态代码分析是指无需运行被测代码,仅通过分析或检查源程序的语法.结构.过程.接口等来检查程序的正确性,找出代码隐藏的错误和缺陷,如参数 ...
随机推荐
- [Heroku] How to pull, push changes
1. First you need to login heroku: heroku login 2. Then you need to download the code: heroku git:cl ...
- Java Web services: WS-Security with Metro--referenc
As you know from "Introducing Metro," the reference implementations of the JAXB 2.x data-b ...
- 根据ip地址从第三方接口获取详细的地理位置
最近项目某个功能需要根据ip地址从第三方接口获取详细的地理位置,从网上找了很多例子,主要接口有新浪的,淘宝的,腾讯的.试了淘宝的,如果是数量级小的还可以,如果数量级达到上十万级就速度慢了,会导致系统崩 ...
- AsyncTask的用法
在开发Android应用时必须遵守单线程模型的原则: Android UI操作并不是线程安全的并且这些操作必须在UI线程中执行.在单线程模型中始终要记住两条法则: 1. 不要阻塞UI线程 2. 确保只 ...
- cgi表单的处理
在HTML中,当客户填写了表单,并按下了发送(submit)按钮后,表单的内容被发送 到了服务器端,一般的,这时就需要有一个服务器端脚本来对表单的内容进行一些处理, 或者是把它们保存起来,或者是按内容 ...
- lex/flex 笔记
Lex的匹配策略: 1. 按最长匹配原则确定被选中的单词 2. 如果一个字符串能被若干正规式匹配,则先匹配排在前面的正规式. lex源程序的写法:Lex源程序必须按照Lex语言的规范来写,其核心是一组 ...
- nodejs中npm工具自身升级
npm官方地址:https://www.npmjs.com/ npm在github上的地址:https://github.com/npm/npm 目前(截止2016-03-15)npm最新版本为3.8 ...
- windows7 图形界面远程 centos6.5
一.首先确定centos已经安装了gnome,因为centos自身没有图形界面,别说远程图形界面方式访问了,就本地图像界面方式都不行 1.首先查看系统的运行级别以及是否安装了桌面环境 1.使用命 ...
- .Net 把网页Html转PDF文件
.Net 把网页Html转PDF文件 此篇主要利用 wkhtmltopdf 进行转换. 一.控制台直接转换 首先到官网http://wkhtmltopdf.org/下载wkhtmltopdf ,下 ...
- 常用CSS技巧资料收集
1.重置浏览器的字体大小 重置浏览器的默认值 ,然后重设浏览器的字体大小你可以使用雅虎的用户界面重置的CSS方案 ,如果你不想下载9MB的文件,代码如下: body,div,dl,dt,dd,ul, ...