对银行卡号进行验证(转)

转自

http://blog.csdn.net/zheng963/article/details/49299993

//Description:  银行卡号Luhm校验

//Luhm校验规则:16位银行卡号(19位通用):

// 1.将未带校验位的 15(或18)位卡号从右依次编号 1 到 15(18),位于奇数位号上的数字乘以 2。

// 2.将奇位乘积的个十位全部相加,再加上所有偶数位上的数字。

// 3.将加法和加上校验位能被 10 整除。

function luhmCheck(bankno){

if (bankno.length < 16 || bankno.length > 19) {

//$("#banknoInfo").html("银行卡号长度必须在16到19之间");

return false;

}

var num = /^\d*$/;  //全数字

if (!num.exec(bankno)) {

//$("#banknoInfo").html("银行卡号必须全为数字");

return false;

}

//开头6位

var 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";

if (strBin.indexOf(bankno.substring(0, 2))== -1) {

//$("#banknoInfo").html("银行卡号开头6位不符合规范");

return false;

}

var lastNum=bankno.substr(bankno.length-1,1);//取出最后一位(与luhm进行比较)

var first15Num=bankno.substr(0,bankno.length-1);//前15或18位

var newArr=new Array();

for(var i=first15Num.length-1;i>-1;i--){    //前15或18位倒序存进数组

newArr.push(first15Num.substr(i,1));

}

var arrJiShu=new Array();  //奇数位*2的积 <9

var arrJiShu2=new Array(); //奇数位*2的积 >9

var arrOuShu=new Array();  //偶数位数组

for(var j=0;j<newArr.length;j++){

if((j+1)%2==1){//奇数位

if(parseInt(newArr[j])*2<9)

arrJiShu.push(parseInt(newArr[j])*2);

else

arrJiShu2.push(parseInt(newArr[j])*2);

}

else //偶数位

arrOuShu.push(newArr[j]);

}

var jishu_child1=new Array();//奇数位*2 >9 的分割之后的数组个位数

var jishu_child2=new Array();//奇数位*2 >9 的分割之后的数组十位数

for(var h=0;h<arrJiShu2.length;h++){

jishu_child1.push(parseInt(arrJiShu2[h])%10);

jishu_child2.push(parseInt(arrJiShu2[h])/10);

}

var sumJiShu=0; //奇数位*2 < 9 的数组之和

var sumOuShu=0; //偶数位数组之和

var sumJiShuChild1=0; //奇数位*2 >9 的分割之后的数组个位数之和

var sumJiShuChild2=0; //奇数位*2 >9 的分割之后的数组十位数之和

var sumTotal=0;

for(var m=0;m<arrJiShu.length;m++){

sumJiShu=sumJiShu+parseInt(arrJiShu[m]);

}

for(var n=0;n<arrOuShu.length;n++){

sumOuShu=sumOuShu+parseInt(arrOuShu[n]);

}

for(var p=0;p<jishu_child1.length;p++){

sumJiShuChild1=sumJiShuChild1+parseInt(jishu_child1[p]);

sumJiShuChild2=sumJiShuChild2+parseInt(jishu_child2[p]);

}

//计算总和

sumTotal=parseInt(sumJiShu)+parseInt(sumOuShu)+parseInt(sumJiShuChild1)+parseInt(sumJiShuChild2);

//计算Luhm值

var k= parseInt(sumTotal)%10==0?10:parseInt(sumTotal)%10;

var luhm= 10-k;

if(lastNum==luhm){

$("#banknoInfo").html("Luhm验证通过");

return true;

}

else{

$("#banknoInfo").html("银行卡号必须符合Luhm校验");

return false;

}

}

时间: 2024-10-11 01:46:58

对银行卡号进行验证(转)的相关文章

输入框内格式化金额、银行卡号

我们在项目中经常遇到需要格式化的金额数和银行卡号,一般我们常见的有两种表现形式:输入框内格式化和输入框外格式化.这里我主要把我在项目中遇到的输入框内部格式化的,代码亮出来,框外的格式化相对简单一点. 页面代码: <div class="wrap"> <input type="text" id="bankCard" placeholder="输入银行卡号"> </div> <div cl

JS校验银行卡号、输入卡号时放大效果

一.(校验格式) function CheckBankNo(t_bankno) { var bankno = $.trim(t_bankno); if(bankno == "") { layer.msg("请填写银行卡号"); return false; } if(bankno.length < 16 || bankno.length > 19) { layer.msg("银行卡号长度必须在16到19之间"); return fals

输入框外部格式化卡号

原理很简单,就是隐藏一个显示格式化的模块,当输入框获取焦点时显示,失去焦点时隐藏即可. 页面代码: <div class="inputCard-wrap"> <input type="text" class="inputCard"> <div class="panelCard"></div> </div> <style type="text/css&q

Android 开发实用方法大全

1.格式化价格,这个经常在计算费用精度的时候用到 /** * 格式化价格 * * @param argStr 传入价格字符串 * @return */ public static String getFloatDotStr(String argStr) { float arg = Float.valueOf(argStr); DecimalFormat fnum = new DecimalFormat("##0.00"); return fnum.format(arg); } 2.获取

史上最全的开发工具类

    API 银行卡管理 → BankCheck checkBankCard : 校验银行卡卡号是否合法 getBankCardCheckCode: 从不含校验位的银行卡卡号采用 Luhm 校验算法获得校验位 getNameOfBank : 通过银行卡的前六位确定判断银行开户行及卡种 SharePreference缓存数据 →AppSharePreferenceMgr put : 保存数据的方法 get : 获取数据的方法 putImage: 保存图片到SharedPreferences ge

史上最全的开发工具类(转)

     API 银行卡管理 → BankCheck checkBankCard : 校验银行卡卡号是否合法getBankCardCheckCode: 从不含校验位的银行卡卡号采用 Luhm 校验算法获得校验位getNameOfBank : 通过银行卡的前六位确定判断银行开户行及卡种 SharePreference缓存数据 →AppSharePreferenceMgr put : 保存数据的方法get : 获取数据的方法putImage: 保存图片到SharedPreferencesgetIma

身份证号验证 银行卡号验证

身份证号验证 /* 审批系统的身份证验证 * 身份证15位编码规则:dddddd yymmdd xx p * dddddd:6位地区编码 * yymmdd: 出生年(两位年)月日,如:910215 * xx: 顺序编码,系统产生,无法确定 * p: 性别,奇数为男,偶数为女 * * 身份证18位编码规则:dddddd yyyymmdd xxx y * dddddd:6位地区编码 * yyyymmdd: 出生年(四位年)月日,如:19910215 * xxx:顺序编码,系统产生,无法确定,奇数为男

校验银行卡号

1.先引入jquery.js 2.接着引入luhmCheck.js //银行卡号Luhm校验 3.看下面的案例: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml&q

L--基于js自制注册页面验证插件

介绍 完全基于javascript的验证插件 js代码 var registerValidate = (function () { var validateObj = { warnInfo:"请按提示输入内容", errorInfo:"您输入的的内容有误,请按提示输入" }; var registerValidate = function () { /*----phone number-------*/ validateObj = { input: document