避免悲劇 JavaScript密碼生成器
我為大家準備了一個密碼生成工具,有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('');
獲得一個密鑰。
原文:http://www.cnblogs.com/enix/archive/2011/12/22/2297913.html
【編輯推薦】