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 $(document).ready() 与window.onload的区别
Dec 28 Javascript
IE本地存储userdata的一个bug说明
Jul 01 Javascript
JavaScript 注册事件代码
Jan 27 Javascript
js 金额文本框实现代码
Feb 14 Javascript
如何解决ligerUI布局时Center中的Tab高度大小
Nov 24 Javascript
Bootstrop实现多级下拉菜单功能
Nov 24 Javascript
详解vue-cli与webpack结合如何处理静态资源
Sep 19 Javascript
详解VueJS应用中管理用户权限
Feb 02 Javascript
微信小程序 行的删除和增加操作实现详解
Sep 29 Javascript
JS实现压缩上传图片base64长度功能
Dec 03 Javascript
JS实现水平移动与垂直移动动画
Dec 19 Javascript
JS call()及apply()方法使用实例汇总
Jul 11 Javascript
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静态类
2006/11/25 PHP
PHP中Date()时间日期函数的使用方法小结
2011/04/20 PHP
8个PHP程序员常用的功能汇总
2014/12/18 PHP
PHP调试的强悍利器之PHPDBG
2016/02/22 PHP
Laravel中基于Artisan View扩展包创建及删除应用视图文件的方法
2016/10/08 PHP
PHP 获取客户端 IP 地址的方法实例代码
2018/11/11 PHP
判断window.onload是否多次使用的方法
2014/09/21 Javascript
js实现感应鼠标图片透明度变化的方法
2015/02/20 Javascript
js实现获取当前时间是本月第几周的方法
2015/08/11 Javascript
JS实现可点击展开与关闭的左侧广告代码
2015/09/02 Javascript
详解JS正则replace的使用方法
2016/03/06 Javascript
关于javascript中限定时间内防止按钮重复点击的思路详解
2016/08/16 Javascript
JS区分Object与Aarry的六种方法总结
2017/02/27 Javascript
js禁止表单重复提交
2017/08/29 Javascript
angular1.x ui-route传参的三种写法小结
2018/08/31 Javascript
如何为vuex实现带参数的 getter和state.commit
2019/01/04 Javascript
详解Vue.js 作用域、slot用法(单个slot、具名slot)
2019/10/15 Javascript
vue.js的状态管理vuex中store的使用详解
2019/11/08 Javascript
浅谈vue的第一个commit分析
2020/06/08 Javascript
JavaScript本地储存:localStorage、sessionStorage、cookie的使用
2020/10/13 Javascript
[02:11]2014DOTA2 TI专访VG战队Fenrir:队伍气氛良好
2014/07/11 DOTA
Python列表list解析操作示例【整数操作、字符操作、矩阵操作】
2017/07/25 Python
python 猴子补丁(monkey patch)
2019/06/26 Python
解决Django中多条件查询的问题
2019/07/18 Python
python颜色随机生成器的实例代码
2020/01/10 Python
使用Pytorch来拟合函数方式
2020/01/14 Python
Keras中的两种模型:Sequential和Model用法
2020/06/27 Python
美国瑜伽品牌:Gaiam
2017/10/31 全球购物
Travelstart沙特阿拉伯:廉价航班、豪华酒店和实惠的汽车租赁优惠
2019/04/06 全球购物
初级Java程序员面试题
2016/03/03 面试题
单位个人查摆问题及整改措施
2014/10/28 职场文书
六年级学生期末评语
2014/12/26 职场文书
2015年小学数学教研组工作总结
2015/05/21 职场文书
医院见习总结
2015/06/24 职场文书
小学毕业感言200字
2015/07/30 职场文书
JavaScript声明变量和数据类型的转换
2022/04/12 Javascript