银行卡算法规则

/**
    *Luhn校验算法校验银行卡号
    *Description:  银行卡号Luhm校验
    *Luhm校验规则:16位银行卡号(19位通用):
    *1.将未带校验位的 15(或18)位卡号从右依次编号 1 到 15(18),位于奇数位号上的数字乘以 2。
    *2.将奇位乘积的个十位全部相加,再加上所有偶数位上的数字。
    *3.将加法和加上校验位能被 10 整除。
    *方法步骤很清晰,易理解,需要在页面引用Jquery.js
    *bankno为银行卡号
    */
    function luhmCheck(bankno) {
        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;
        var my = false;
        if (lastNum == luhm) {//Luhm验证通过
            my = true;
        }
        else {//银行卡号必须符合Luhm校验
            my = false;
        }
        return my;
    }

  

时间: 2024-10-13 00:28:20

银行卡算法规则的相关文章

UCenter密码算法规则和生成方法

如果想平滑的使用UCenter,那么这篇文章务必 康盛的系列产品,包括Discuz.UCHome.Supesite都集成了同一个用户系统--UCenter,用户登录的密码也保存在 UCenter中,对于其他系统集成或导出数据到UCenter系统,通常会遇到密码生成的问题,这里就讨论一下UCenter的用户密码算法规则和生成 方法. 密码通常使用MD5对用户密码HASH 后保存在数据库中的方法,如果黑客拿到了这个HASH数值,那么可以采用字典的方式暴力破解,如果这个字典数据库足够大,并且字典比较符

银行卡编码规则及检验算法详解

原文: https://blog.csdn.net/wmlml/article/details/54345413 一.银行卡结构 XXXXXX XXXXXXXXXXXX X 发卡行标识代码 自定义位 校验码 根据ISO标准,银行卡长度一般在13-19位,国际上也有12位的.银联标准卡卡长度一般是在16-19位,双组织卡也有13-19位的. 二.发卡行标识代码 发卡行标识代码Bank Identification Number(BIN),又叫发卡机构标识代码Issuer Identificatio

后台银行卡算法

/** * [cardList 银行卡号是否正确] * luha 算法 * @return [type] bool */ public static function check_card($no) { $return = false; $arr_no = str_split($no); $last_n = $arr_no[count($arr_no)-1]; krsort($arr_no); $i = 1; $total = 0; foreach ($arr_no as $n){ if($i%

利用WordPress用户密码算法规则修改用户密码

WordPress用户密码保存在wp_users数据表的user_pass字段,密码是通过Portable PHP password hashing framework类产生的, 密码的形式是随机且不可逆,同一个明文的密码在不同时间,产生的密文也不一样,相对来说较为安全. WordPress用户密码产生的过程是:当需要生成用户密码的时候,随机产生了一个salt,然后将salt和password相加,又进行了count次md5,最后和encode64的hash数值累加,就得到了一个以$P$开头的密

百度排名规则及算法(百度内部资料)

今日一位自称百度内部人疯疯癫癫的给我上了一节百度内部的课程,那就是关于百度排名规则以及算法方面的,刚刚听的时候貌似疯癫,越到后面,越是感觉茅塞顿开,以此分享出来给大家. 要想百度给你网站排名,只有三种理由,第一你给百度钱了,第二你是百度旗下的公司或产品,第三你提供有价值的内容,提高了百度搜索的用户体验了.除去这三个理由,你别想着要百度给你排名,那么我们围绕这三种理由,展开我们的分析. 百度竞价 百度竞价主要是根据关键词出价获得排名的,对于百度竞价我了解的不是很多,大致我清楚,当你出价1元一个点击

百度去年算法更新之后站长们应该何去何从

2016年6月份,打击欺骗下载和无告知的捆绑下载之欺骗,7月份,打击移动页强制用户下载或调起APP的行为之冰桶3.0,8月份,打击网站窃取用户联系方式等隐私行为之天网算法,9月份,代价移动页面广告阻碍用户获取内容的行为之冰桶4.0,10月份,打击移动页上的恶劣色情博彩广告之冰桶4.5,11月份,打击收费软文租售目录行为之蓝天算法. 以上,即2016年百度算法之盘点.来看看出各种算法的时候网站们都出现了怎样的问题,被2016年算法们的"步步相逼",2017年站长们又该如何处之. 天网算法

A*算法入门

一:概述 A*算法在游戏中应用是十分广泛的,许许多多的游戏在寻路方面都会考虑使用该算法(当然除该算法外,前辈们也想出很多其他办法),它是一种启发式的寻路搜索算法.今天这边重点全面分析探讨A*算法.  二:术语 此处对接下来将要讨论的内容中的相关术语约定如下: start-node       :起始节点.即:用户请求寻路时的起点 end-node         :目标节点/称之为结束节点/终点.即:用户请求寻路的终点/目的地点 current-node    :当前节点.即:当前正在分析的节点

Rete算法

RETE算法介绍一. rete概述Rete算法是一种前向规则快速匹配算法,其匹配速度与规则数目无关.Rete是拉丁文,对应英文是net,也就是网络.Rete算法通过形成一个rete网络进行模式匹配,利用基于规则的系统的两个特征,即时间冗余性(Temporal redundancy)和结构相似性(structural similarity),提高系统模式匹配效率.二. 相关概念2.1  事实(fact):事实:对象之间及对象属性之间的多元关系.为简单起见,事实用一个三元组来表示:(identifi

向量时钟算法简介——本质类似MVCC

转自:http://blog.chinaunix.net/uid-27105712-id-5612512.html 一.使用背景 先说一下需要用到向量时钟的场景.我们在写数据时候,经常希望数据不要存储在单点.如db1,db2都可以同时提供写服务,并且都存有全量数据.而client不管是写哪一个db都不用担心数据写乱问题.但是现实场景中往往会碰到并行同时修改.导致db1和db2数据不一致.于是乎就有人想出一些解决策略.向量时钟算是其中一种.简单易懂.但是并没有彻底解决冲突问题,现实分布式存储补充了