JavaScript随机生成信用卡卡号的方法


Posted in Javascript onApril 07, 2015

本文实例讲述了JavaScript随机生成信用卡卡号的方法。分享给大家供大家参考。具体分析如下:

这段JS代码根据信用卡卡号产生规则随机生成信用卡卡号,是可以通过验证的,仅供学习参考,请不要用于非法用途,否则后果自负。

var visaPrefixList = new Array(
 "4539",
 "4556",
 "4916",
 "4532",
 "4929",
 "40240071",
 "4485",
 "4716",
 "4"
);
var mastercardPrefixList = new Array(
 "51",
 "52",
 "53",
 "54",
 "55"
);
var amexPrefixList = new Array(
 "34",
 "37"
);
var discoverPrefixList = new Array("6011");
var dinersPrefixList = new Array(
 "300",
 "301",
 "302",
 "303",
 "36",
 "38"
);
var enRoutePrefixList = new Array(
 "2014",
 "2149"
);
var jcbPrefixList = new Array(
 "35"
);
var voyagerPrefixList = new Array("8699");
function strrev(str) {
  if (!str) return '';
  var revstr='';
  for (i = str.length-1; i>=0; i--)
   revstr+=str.charAt(i)
  return revstr;
}
/*
'prefix' is the start of the CC number as a string, 
any number of digits.
'length' is the length of the CC number to generate. 
Typically 13 or 16
*/
function completed_number(prefix, length) {
 var ccnumber = prefix;
 // generate digits
 while ( ccnumber.length < (length - 1) ) {
  ccnumber += Math.floor(Math.random()*10);
 }
 // reverse number and convert to int
 var reversedCCnumberString = strrev( ccnumber );
 var reversedCCnumber = new Array();
 for ( var i=0; i < reversedCCnumberString.length; i++ ) {
  reversedCCnumber[i] = parseInt(reversedCCnumberString.charAt(i));
 }
 // calculate sum
 var sum = 0;
 var pos = 0;
 while ( pos < length - 1 ) {
  odd = reversedCCnumber[ pos ] * 2;
  if ( odd > 9 ) {
   odd -= 9;
  }
  sum += odd;
  if ( pos != (length - 2) ) {
 
   sum += reversedCCnumber[ pos +1 ];
  }
  pos += 2;
 }
 // calculate check digit
 var checkdigit = ((Math.floor(sum/10)+1)*10-sum)%10;
 ccnumber += checkdigit;
 return ccnumber;
}
function credit_card_number(prefixList, length, howMany) {
 var result = new Array();
 for (var i = 0; i < howMany; i++) {
  var randomArrayIndex = Math.floor(Math.random() * 
 prefixList.length);
  var ccnumber = prefixList[ randomArrayIndex ];
  result.push( completed_number(ccnumber, length) );
 }
 return result;
}

调用方法:

将上面的代码保存为gencc.js文件

<html>
<head>
<script src="gencc.js" type="text/javascript"></script>
</head>
<body>
<h3>VISA:</h3>
<script>
var visa = credit_card_number(visaPrefixList, 16, 3);
document.write( visa );
</script>
<h3>Amex:</h3>
<script>
var amex = credit_card_number(amexPrefixList, 15, 3);
document.write( amex );
</script>
</body>
</html>

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

Javascript 相关文章推荐
JQUERY复选框CHECKBOX全选,取消全选
Aug 30 Javascript
js实现页面转发功能示例代码
Aug 05 Javascript
探讨js中的双感叹号判断
Nov 11 Javascript
禁止页面刷新让F5快捷键及右键都无效
Jan 22 Javascript
仅30行代码实现Javascript中的MVC
Feb 15 Javascript
表单元素值获取方式js及java方式的简单实例
Oct 15 Javascript
微信小程序开发一键登录 获取session_key和openid实例
Nov 23 Javascript
详解jQuery中的easyui
Sep 02 jQuery
VUE 自定义组件模板的方法详解
Aug 30 Javascript
JavaScript进阶(三)闭包原理与用法详解
May 09 Javascript
JS Canvas接口和动画效果大全
Apr 29 Javascript
Vue组件更新数据v-model不生效的解决
Apr 02 Vue.js
JavaScript实现信用卡校验方法
Apr 07 #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
You might like
php表单提交实例讲解
2015/11/12 PHP
laravel框架中表单请求类型和CSRF防护实例分析
2019/11/23 PHP
几个有趣的Javascript Hack
2010/07/24 Javascript
教你如何使用PHP输出中文JSON字符串
2014/05/22 Javascript
checkbox选中与未选中判断示例
2014/08/04 Javascript
node.js中的fs.readSync方法使用说明
2014/12/17 Javascript
Jquery1.9.1源码分析系列(十五)动画处理之外篇
2015/12/04 Javascript
详解javascript传统方法实现异步校验
2016/01/22 Javascript
JS检测页面中哪个HTML标签触发点击事件的方法
2016/06/17 Javascript
Vuejs实现带样式的单文件组件新方法
2017/05/02 Javascript
常见的浏览器Hack技巧整理
2017/06/29 Javascript
浅谈Vue.js应用的四种AJAX请求数据模式
2017/08/30 Javascript
vue watch深度监听对象实现数据联动效果
2018/08/16 Javascript
js实现黑白div块画空心的图形
2018/12/13 Javascript
详解javascript replace高级用法
2019/02/17 Javascript
详解实现一个通用的“划词高亮”在线笔记功能
2019/04/23 Javascript
微信小程序中悬浮窗功能的实现代码
2019/08/02 Javascript
React传值 组件传值 之间的关系详解
2019/08/26 Javascript
解决qrcode.js生成二维码时必须定义一个空div的问题
2020/07/09 Javascript
Element DateTimePicker日期时间选择器的使用示例
2020/07/27 Javascript
vue实现单一筛选、删除筛选条件
2020/10/26 Javascript
对pycharm 修改程序运行所需内存详解
2018/12/03 Python
用Python逐行分析文件方法
2019/01/28 Python
python实现代码统计器
2019/09/19 Python
django和flask哪个值得研究学习
2020/07/31 Python
CSS3媒体查询(Media Queries)介绍
2013/09/12 HTML / CSS
Html5 实现微信分享及自定义内容的流程
2019/08/20 HTML / CSS
YSL Beauty加拿大官方商城:圣罗兰美妆加拿大
2017/05/15 全球购物
宠物店的创业计划书范文
2014/01/11 职场文书
关于廉洁的广播稿
2014/01/30 职场文书
大学优秀班集体申报材料
2014/05/23 职场文书
政府采购方案
2014/06/12 职场文书
个人剖析材料范文
2014/09/30 职场文书
MySQL系列之十一 日志记录
2021/07/02 MySQL
Java反应式框架Reactor中的Mono和Flux
2021/07/25 Java/Android
cypress测试本地web应用
2022/06/01 Javascript