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

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

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

<!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传入一个这样的函数

  

sort真是强大啊。
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的随机数序号

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

 

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

 

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

password.join('');

 

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

你可能感兴趣的:(JavaScript)