文档章节

jQuery实现银行卡Luhm验证

耳东Ed
 耳东Ed
发布于 2017/09/07 04:11
字数 472
阅读 2
收藏 0
// Description:  银行卡号Luhm校验
// Luhm校验规则:16位银行卡号(19位通用):
// 1.将未带校验位的 15(或18)位卡号从右依次编号 1 到 15(18),位于奇数位号上的数字乘以 2。
// 2.将奇位乘积的个十位全部相加,再加上所有偶数位上的数字。
// 3.将加法和加上校验位能被 10 整除。
// 方法步骤很清晰,易理解,需要在页面引用Jquery.js    
// bankno为银行卡号 
luhmCheck: function(bankno){
    // 取出最后一位(与luhm进行比较)
    var lastNum=bankno.substr(bankno.length-1,1);
    // 前15或18位
    var first15Num=bankno.substr(0,bankno.length-1);
    var newArr=new Array();
    //前15或18位倒序存进数组
    for(var i=first15Num.length-1;i>-1;i--){    
        newArr.push(first15Num.substr(i,1));
    }
    // 奇数位*2的积 <9
    var arrJiShu=new Array();  
    // 奇数位*2的积 >9
    var arrJiShu2=new Array(); 
    // 偶数位数组
    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]);
    }
    // 奇数位*2 >9 的分割之后的数组个位数
    var jishu_child1=new Array();
    // 奇数位*2 >9 的分割之后的数组十位数
    var jishu_child2=new Array();
    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){
        return true;
    }
    else{
        return false;
    }        
}

 

© 著作权归作者所有

共有 人打赏支持
耳东Ed
粉丝 0
博文 4
码字总数 1176
作品 0
海淀
数据库管理员
2011年12月最新JQuery插件汇总

jQuery的工具提示插件 Tipped jQuery表格插件 colResizable jQuery虚拟键盘插件 jQuery keyboard Minimit Gallery 用于显示相册、幻灯片、卷帘等效果 jQuery 幻灯效果显示插件 Diapo jQuery...

晨曦之光
2012/02/24
0
0
自定义jQuery插件Step by Step

自定义jQuery插件Step by Step 1.1.1 摘要 随着前端和后端技术的分离,各大互联网公司对于Mobile First理念都是趋之若鹜的,为了解决网页在不同移动设备上的显示效果,其中一个解决方案就是R...

wolf_su
2013/07/04
0
0
Web开发者必知的12款jQuery插件

jQuery插件能够增强网站的可用性,有效地改善用户体验,还可以大大减少创建一个新站点的开发时间。现在的jQuery插件很多,尽可以根据您的项目要求来选择,不过也有一些插件很好用,几乎各种项...

迷路的阿修罗
2010/12/15
0
0
GBin1教程:使用jQuery插件jquery.validationEngine实现表单验证功能

日期:2011/10/26 作者:Terry li/GBin1.com Web应用及其网站开发中常需要做用户输入内容校验,使用jQuery的插件可以快速的帮助你实现相关的功能,今天我们将介绍如何使用jQuery输入验证插件...

gbin1
2011/10/26
0
0
表单验证:nice Validator 与 jQuery Validation 对比

提要 最近,有人提到jQuery Validation Plugin,甚至有人怀疑 nice Validator 和 这个插件系同一个作者。我好想说,你太有想象力了-。-!jQuery Validation全程的鹰文,nice Validator 全程的...

JonyZhang
2013/08/02
0
7

没有更多内容

加载失败,请刷新页面

加载更多

将桌面捕获到虚拟摄像头

当然你可以直接用现成的虚拟摄像头软件实现这个功能。不过当初我开发这个插件的原因是,需要在Flash产品里面共享桌面,如果此时需要引导用户安装一个第三方的虚拟摄像头体验不好,所以公司希...

一个灰
29分钟前
1
0
Linux 配置网络绑定

1. 常见的网卡绑定驱动模式: mod=0 (balance-rr) Round-robin 衡抡循环策略 特点: 传输数据包顺序是依次传输(即:第1个包走eth0,下一个包就走eth1.一直循环下去,直到最后一个传输完毕),...

JeremyTown
38分钟前
0
0
VS code 编辑器使用技能

VS code 文档:https://code.visualstudio.com/docs/getstarted/locales 1、安装中文扩展包 打开扩展包按钮(最左上角从上往下数第5个按钮或者快捷键 Ctrl + Shift + X) 搜索语言包categor...

削个椰子皮_给个梨
47分钟前
4
0
Django 2.1.2项目中创建一个应用

Django 2.1.2项目中创建一个应用: 1.新建一个应用(app), 名称叫 learn python manage.py startapp learn # learn 是一个app的名称 2.在learn应用中修改视图文件views.py: # Create your vi...

MichaelShu
48分钟前
5
0
Swagger中配置了@ApiModelProperty的allowableValues属性但不显示的问题

现在用Swagger来生成API文档的例子已经非常多了,今天碰到开发同事问了一个问题,帮着看了一下,主要还是配置方法的问题,所以记录一下。如果您也碰到了同样的问题,希望本文对您有用。 问题...

程序猿DD
今天
7
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部