[javascript]避免悲剧 密码生成器

最近被暴库的很多,密码安全成为重大问题!如何避免简单密码呢?还在冥思苦想密码?no

我为大家准备了一个密码生成工具,有0-9和a-k的英文字母组成,数字是乱序排列。字母随机一个替换掉一个数字,生成一个长度为10的密码。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
        "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"
<html xmlns="http://www.w3.org/1999/xhtml"
<head> 
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> 
    <title></title> 
</head> 
<body> 
<div> 
   
<input id="strat" type="button" value="开始" /> 
<textarea rows="10" cols="25" id="password"></textarea> 
</div> 
<script type="text/javascript"
void function(window,doc,undefined){ 
    var array=[],text='abcdefghijk',key,password='',btn=doc.getElementById('strat'),textarea=doc.getElementById('password'); 
   
    function unorderedArray(array){ 
        if(({}).toString.call(array).indexOf('Array')===-1) return
        var arr=[],value=array.toString(); 
        arr=array.sort(function(){return Math.random()>0.5?-1:1;}); 
        (arr.toString()===value) && arguments.callee(array); 
        return arr; 
    
   
   
    btn.onclick=function(){ 
        key=Math.random().toFixed(1) * 10-1; 
        array=[0,1,2,3,4,5,6,7,8,9]; 
        password=unorderedArray(array); 
        password[key]=text[key]; 
        textarea.innerHTML=password.join(''); 
    
}(window,document); 
   
   
    //console.log(unorderedArray(a)); 
</script> 
   
</body> 
</html> 

  

怎样乱序排列数组,本人数学比较烂。搜索了一下给array的sort传入一个这样的函数

  

1
sort真是强大啊。
1
2
3
4
5
6
7
function unorderedArray(array){
        if(({}).toString.call(array).indexOf('Array')===-1) return;
        var arr=[],value=array.toString();
        arr=array.sort(function(){return Math.random()>0.5?-1:1;});
        (arr.toString()===value) && arguments.callee(array);
        return arr;
}

 

在用这个方法的时候要避免生成的数组和传入的数组一样,颇废了点功夫,因为数组是复杂类型,有修改所有的都会有变化。所以用一个变量去缓存了传入的数组的值value=array.toString(),然后我生成的数组的值比较一下如果相对就递归一次。保证生成的数组不是顺序的。

 

用下面的代码生成一个0-9的随机数序号

1
Math.random().toFixed(1) * 10-1;

 

用这个序号去获得a-k的一个字母,用这个字母去替换数组中序号相应位置的数字。

 

在用数组的join方法把获得的数组字符串化

password.join('');

 

获得一个密钥。欢迎大家使用,博客园不让贴纯代码的贴,所以废话了这么多。大家拷贝代码直接用就行了,勿怪!

posted @   小玉西瓜  阅读(2433)  评论(12编辑  收藏  举报
编辑推荐:
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
阅读排行:
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
点击右上角即可分享
微信分享提示