zoukankan      html  css  js  c++  java
  • ASP.NET中的随机密码生成

    第一种方法:
    用.NET中的 Sytem.Guid.NewGuid().ToString() 生成,实际上是对一个128bit数字的十六进制输出.
    生成的字符由0-9和a-z这几种字符组成,也可能会有“-”字符分割.

    string strNewPW = System.Guid.NewGuid().ToString();

    结果可能会是:7f44aed7-f8a4-4229-b64a-6a3e50d920e0
    处理一下,去掉其中的“-”字符,剩下的是由32个阿拉伯数字和英文字母组成的串,再按自己的要求截取指定长度的字串.
    截取8位:

    string strNewPW = System.Guid.NewGuid().ToString().Replace("-", "").Substring(0, 8);

    结果为:7f44aed7

    or (直接获取)

      string strNewPW =Guid.NewGuid().ToString("n")
    第二种方法:
    实现方法:

        protected void Page_Load(object sender, EventArgs e)
        {
            //设定字符范围为:大小写字母及数字的随机字符串.
            string strPwChar = "abcdefghijklmnopqrstuvwxyz0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";
            //截取长度为8.
            string strNewPW = MakePassword(strPwChar, 8); 
            Response.Write(strNewPW);
        }
        /// <summary> 
        /// 生成随机字符串
        /// </summary> 
        /// <param name="strPwChar">传入生成的随机字符串可以使用哪些字符</param>
        /// <param name="intlen">传入生成的随机字符串的长度</param>
        public static string MakePassword(string strPwChar, int intlen)
        {
            string strRe = "";
            int iRandNum;
            Random rnd = new Random();
            for (int i = 0; i < intlen; i++)
            {
                iRandNum = rnd.Next(strPwChar.Length);
                strRe += strPwChar[iRandNum];
            }
            return strRe;
        } 

    结果为:Qk8JW61c
    方法 MakePassword 接受两个参数,strPwChar参数指定生成的随机密码串可以使用哪些字符,intlen指定生成的随机密码串的长度。有了这两个参数,通过调用 Random 类的 Next() 方法,先获得一个大于或等于 0 而小于 intlen 长度的整数,以该数作为索引值,从可用字符串中随机取字符,以指定的密码长度为循环次数,依次连接取得的字符,最后即得到所需的随机密码串了。 

  • 相关阅读:
    MongoVUE破解方法(转)
    Apache和IIS共享80端口,支持多域名
    让作业飞吧,与屌丝兄弟们分享我的分布式作业调度平台 【拥抱开源,拥抱作业调度的神器Quartz.net】
    关于Nbearlite 访问PostgreSql,MySql,Sqlite的Bug
    php5.4.6/5.3.16/5.2.17安装(In windows),配置(转)
    MSSQL翻页存储过程
    话说客户端连接mongoDB的连接参数(转载)
    关于Windows频繁打开关闭端口时出现的问题(转至老赵)
    zeromq的几种模式(转)
    如何设置代理服务器上网
  • 原文地址:https://www.cnblogs.com/xiaoma-qi/p/5539302.html
Copyright © 2011-2022 走看看