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 相关文章推荐
javascript 验证日期的函数
Mar 18 Javascript
通过jquery还原含有rowspan、colspan的table的实现方法
Feb 10 Javascript
jQuery Animation实现CSS3动画示例介绍
Aug 14 Javascript
js克隆对象、数组的常用方法介绍
Sep 26 Javascript
微信小程序模板之分页滑动栏
Feb 10 Javascript
Zepto实现密码的隐藏/显示
Apr 07 Javascript
使用DataTable插件实现异步加载数据
Nov 19 Javascript
vue iView 上传组件之手动上传功能
Mar 16 Javascript
vue如何将v-for中的表格导出来
May 07 Javascript
Three.js实现简单3D房间布局
Dec 30 Javascript
VUE 解决mode为history页面为空白的问题
Nov 01 Javascript
JavaScript 链表定义与使用方法示例
Apr 28 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 清除网页病毒的方法
2008/12/05 PHP
PHP中获取变量的变量名的一段代码的bug分析
2011/07/07 PHP
php 阴历-农历-转换类代码
2012/01/16 PHP
Linux下实现PHP多进程的方法分享
2012/08/16 PHP
PHP json格式和js json格式 js跨域调用实现代码
2012/09/08 PHP
php 批量生成html,txt文件的实现代码
2013/06/26 PHP
php跨站攻击实例分析
2014/10/28 PHP
php获取QQ头像并显示的方法
2014/12/23 PHP
帝国cms目录结构分享
2015/07/06 PHP
PHP Web木马扫描器代码分享
2015/09/06 PHP
分享一个自定义的console类 让你不再纠结JS中的调试代码的兼容
2012/04/20 Javascript
浅谈javascript回调函数
2014/12/07 Javascript
JavaScript中的标签语句用法分析
2015/02/10 Javascript
js简单工厂模式用法实例
2015/06/30 Javascript
JS+CSS实现自适应选项卡宽度的圆角滑动门效果
2015/09/15 Javascript
JavaScript禁止复制与粘贴的实现代码
2016/05/16 Javascript
纯JS实现弹性导航条效果
2017/03/06 Javascript
ReactNative 之FlatList使用及踩坑封装总结
2017/11/29 Javascript
使用 vue 实例更好的监听事件及vue实例的方法
2019/04/22 Javascript
vue+webpack 更换主题N种方案优劣分析
2019/10/28 Javascript
Vue+Node实现商品列表的分页、排序、筛选,添加购物车功能详解
2019/12/07 Javascript
你知道JavaScript Symbol类型怎么用吗
2020/01/08 Javascript
JavaScript语句错误throw、try及catch实例解析
2020/08/18 Javascript
python 中文字符串的处理实现代码
2009/10/25 Python
详解Python中的循环语句的用法
2015/04/09 Python
python 对dataframe下面的值进行大规模赋值方法
2018/06/09 Python
python中pytest收集用例规则与运行指定用例详解
2019/06/27 Python
pytorch实现建立自己的数据集(以mnist为例)
2020/01/18 Python
Django如何实现密码错误报错提醒
2020/09/04 Python
美国专业级皮肤病和spa品质护肤品的高级零售网站:SkinCareRx
2017/02/06 全球购物
英国网络托管和域名领导者:Web Hosting UK
2017/10/15 全球购物
澳大利亚当地最大的时装生产商:Cue
2018/08/06 全球购物
道歉信怎么写
2015/05/12 职场文书
2016全国“质量月”活动标语口号
2015/12/26 职场文书
2019自荐信该如何写呢?
2019/07/05 职场文书
Golang实现可重入锁的示例代码
2022/05/25 Golang