密码生成器

最近被暴库的很多,密码安全成为重大问题!如何避免简单密码呢?还在冥思苦想密码?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" 
<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( '' );

 

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

你可能感兴趣的:(生成)