Javascript验证Visa和MasterCard信用卡号

//visa
<HTML>
    <head>
        <title>Visa Example</title>
        <script type="text/javascript">
                function luhnCheckSum(sCardNum) {
                    var iOddSum = 0;
                    var iEvenSum = 0;
                    var bIsOdd = true;
                    for (var i=sCardNum.length-1; i >= 0; i--) {
                        var iNum = parseInt(sCardNum.charAt(i));
                        if (bIsOdd) {
                            iOddSum += iNum;
                        } else {
                            iNum = iNum * 2;
                            if (iNum > 9) {
                                iNum = eval(iNum.toString().split("").join("+"));
                            }
                            iEvenSum += iNum;
                        }
                        bIsOdd = !bIsOdd;
                    }
                    return ((iEvenSum + iOddSum) % 10 == 0);
                }
                function isValidVisa(sText) {
                    var reVisa = /^(4\d{12}(?:\d{3})?)$/;
                    if (reVisa.test(sText)) {
                        return luhnCheckSum(RegExp.$1);
                    } else {
                        return false;
                    }
                }
                function validate() {
                    var oInput1 = document.getElementById("txt1");
                    if (isValidVisa(oInput1.value)) {
                        alert("Valid");
                    } else {
                        alert("Invalid!");
                    }
                }
        </script>
    </head>
    <body>
        <P>Visa Number: <input type="text" id="txt1" /><br />
        <input type="button" value="Validate" onclick="validate()" /></p>
    </body>
</html>
//MasterCard
view sourceprint?
<html>
    <head>
        <title>MasterCard Example</title>
        <script type="text/javascript">
                function luhnCheckSum(sCardNum) {
                    var iOddSum = 0;
                    var iEvenSum = 0;
                    var bIsOdd = true;
                    for (var i=sCardNum.length-1; i >= 0; i--) {
                        var iNum = parseInt(sCardNum.charAt(i));
                        if (bIsOdd) {
                            iOddSum += iNum;
                        } else {
                            iNum = iNum * 2;
                            if (iNum > 9) {
                                iNum = eval(iNum.toString().split("").join("+"));
                            }
                            iEvenSum += iNum;
                        }
                        bIsOdd = !bIsOdd;
                    }
                    return ((iEvenSum + iOddSum) % 10 == 0);
                }
                function isValidMasterCard(sText) {
                    var reMasterCard = /^(5[1-5]\d{2})[\s\-]?(\d{4})[\s\-]?(\d{4})[\s\-]?(\d{4})$/;
                    if (reMasterCard.test(sText)) {
                        var sCardNum = RegExp.$1 + RegExp.$2 + RegExp.$3 + RegExp.$4;
                        return luhnCheckSum(sCardNum);
                    } else {
                        return false;
                    }
                }
                function validate() {
                    var oInput1 = document.getElementById("txt1");
                    if (isValidMasterCard(oInput1.value)) {
                        alert("Valid");
                    } else {
                        alert("Invalid!");
                    }
                }
        </script>
    </head>
    <body>
        <P>MasterCard Number: <input type="text" id="txt1" /><br />
        <input type="button" value="Validate" onclick="validate()" /></p>
    </body>
</html>
posted @   与时俱进  阅读(1731)  评论(0编辑  收藏  举报
编辑推荐:
· 智能桌面机器人:用.NET IoT库控制舵机并多方法播放表情
· Linux glibc自带哈希表的用例及性能测试
· 深入理解 Mybatis 分库分表执行原理
· 如何打造一个高并发系统?
· .NET Core GC压缩(compact_phase)底层原理浅谈
阅读排行:
· 手把手教你在本地部署DeepSeek R1,搭建web-ui ,建议收藏!
· 新年开篇:在本地部署DeepSeek大模型实现联网增强的AI应用
· Janus Pro:DeepSeek 开源革新,多模态 AI 的未来
· 互联网不景气了那就玩玩嵌入式吧,用纯.NET开发并制作一个智能桌面机器人(三):用.NET IoT库
· 【非技术】说说2024年我都干了些啥
友情链接:同里老宅院民居客栈
点击右上角即可分享
微信分享提示