JavaScript实现信用卡校验方法


Posted in Javascript onApril 07, 2015

本文实例讲述了JavaScript实现信用卡校验方法。分享给大家供大家参考。具体分析如下:

这里JavaScript版的信用卡校验代码,采用了Luhn算法

function isValidCreditCard(type, ccnum) {
  if (type == "Visa") {
   // Visa: length 16, prefix 4, dashes optional.
   var re = /^4\d{3}-?\d{4}-?\d{4}-?\d{4}$/;
  } else if (type == "MC") {
   // Mastercard: length 16, prefix 51-55, dashes optional.
   var re = /^5[1-5]\d{2}-?\d{4}-?\d{4}-?\d{4}$/;
  } else if (type == "Disc") {
   // Discover: length 16, prefix 6011, dashes optional.
   var re = /^6011-?\d{4}-?\d{4}-?\d{4}$/;
  } else if (type == "AmEx") {
   // American Express: length 15, prefix 34 or 37.
   var re = /^3[4,7]\d{13}$/;
  } else if (type == "Diners") {
   // Diners: length 14, prefix 30, 36, or 38.
   var re = /^3[0,6,8]\d{12}$/;
  }
  if (!re.test(ccnum)) return false;
  // Remove all dashes for the checksum 
  //checks to eliminate negative numbers
  ccnum = ccnum.split("-").join("");
  // Checksum ("Mod 10")
  // Add even digits in even length strings 
  //or odd digits in odd length strings.
  var checksum = 0;
  for (var i=(2-(ccnum.length % 2)); i<=ccnum.length; i+=2) {
   checksum += parseInt(ccnum.charAt(i-1));
  }
  // Analyze odd digits in even length strings
  //or even digits in odd length strings.
  for (var i=(ccnum.length % 2) + 1; i<ccnum.length; i+=2) {
   var digit = parseInt(ccnum.charAt(i-1)) * 2;
   if (digit < 10) { checksum += digit; }
   else { checksum += (digit-9); }
  }
  if ((checksum % 10) == 0) return true; else return false;
}

希望本文所述对大家的javascript程序设计有所帮助。

Javascript 相关文章推荐
js实现在字符串中提取数字
Nov 05 Javascript
javascript制作的网页侧边弹出框思路及实现代码
May 21 Javascript
基于Angularjs实现分页功能
May 30 Javascript
AngularJs学习第八篇 过滤器filter创建
Jun 08 Javascript
深入浅出ES6之let和const命令
Aug 25 Javascript
强大Vue.js组件浅析
Sep 12 Javascript
js实现可输入可选择的select下拉框
Dec 21 Javascript
解决webpack -p压缩打包react报语法错误的方法
Jul 03 Javascript
Angular6 正则表达式允许输入部分中文字符
Sep 10 Javascript
Vue infinite update loop的问题解决
Apr 23 Javascript
JavaScript 斐波那契数列 倒序输出 输出100以内的质数代码实例
Sep 11 Javascript
vue设置全局访问接口API地址操作
Aug 14 Javascript
jQuery控制网页打印指定区域的方法
Apr 07 #Javascript
JavaScript使用指针操作实现约瑟夫问题实例
Apr 07 #Javascript
jquery.form.js实现将form提交转为ajax方式提交的方法
Apr 07 #Javascript
JavaScript中字符串分割函数split用法实例
Apr 07 #Javascript
JavaScript使用二分查找算法在数组中查找数据的方法
Apr 07 #Javascript
JavaScript给按钮绑定点击事件(onclick)的方法
Apr 07 #Javascript
JS 作用域与作用域链详解
Apr 07 #Javascript
You might like
php下通过POST还是GET来传值
2008/06/05 PHP
PHP文章按日期(月日)SQL归档语句
2012/11/29 PHP
浅析php过滤html字符串,防止SQL注入的方法
2013/07/02 PHP
PHP 使用pcntl和libevent 实现Timer功能
2013/10/27 PHP
PHP中$_FILES的使用方法及注意事项说明
2014/02/14 PHP
php获取错误信息的方法
2015/07/17 PHP
smarty高级特性之过滤器的使用方法
2015/12/25 PHP
详解laravel安装使用Passport(Api认证)
2018/07/27 PHP
利用ASP发送和接收XML数据的处理方法与代码
2007/11/13 Javascript
超越Jquery_01_isPlainObject分析与重构
2010/10/20 Javascript
jquery里的正则表达式说明
2011/08/03 Javascript
动态的改变IFrame的高度实现IFrame自动伸展适应高度
2012/12/28 Javascript
ajax处理php返回json数据的实例代码
2013/01/24 Javascript
jQuery中first()方法用法实例
2015/01/06 Javascript
js实现简单计算器
2015/11/22 Javascript
JavaScript排序算法动画演示效果的实现方法
2016/10/18 Javascript
Nodejs下DNS缓存问题浅析
2016/11/16 NodeJs
jQuery实现简单的手风琴效果
2020/04/17 jQuery
jQuery超简单遮罩层实现方法示例
2018/09/06 jQuery
深入浅析Vue.js 中的 v-for 列表渲染指令
2018/11/19 Javascript
Vue封装的组件全局注册并引用
2019/07/24 Javascript
JavaScript this在函数中的指向及实例详解
2019/10/14 Javascript
Django中使用locals()函数的技巧
2015/07/16 Python
python 第三方库的安装及pip的使用详解
2017/05/11 Python
python实现屏保程序(适用于背单词)
2019/07/30 Python
python多线程分块读取文件
2019/08/29 Python
python使用rsa非对称加密过程解析
2019/12/28 Python
Python 中@property的用法详解
2020/01/15 Python
彻底搞懂python 迭代器和生成器
2020/09/07 Python
python利用opencv保存、播放视频
2020/11/02 Python
HTML5 SEO优化的一些建议
2020/08/27 HTML / CSS
英国领先的新鲜松露和最好的松露产品供应商:TruffleHunter
2019/08/26 全球购物
领导干部廉政自律承诺书
2014/05/26 职场文书
小学生一分钟演讲稿
2014/08/26 职场文书
合作经营协议书范本
2014/09/16 职场文书
暂住证证明
2015/06/19 职场文书