zoukankan      html  css  js  c++  java
  • 密码生成器

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

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

  • 相关阅读:
    Hadoop-CDH源码编译
    HBase框架基础(四)
    HBase框架基础(三)
    Scala基础简述
    HBase框架基础(一)
    NOI2015 软件包管理器
    可持久化数据结构入门
    树链剖分 入门
    NOIP2009 最优贸易
    高斯消元 模板
  • 原文地址:https://www.cnblogs.com/Leo_wl/p/2298925.html
Copyright © 2011-2022 走看看