ASP.NET中的随机密码生成

Posted tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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 长度的整数,以该数作为索引值,从可用字符串中随机取字符,以指定的密码长度为循环次数,依次连接取得的字符,最后即得到所需的随机密码串了。 

以上是关于ASP.NET中的随机密码生成的主要内容,如果未能解决你的问题,请参考以下文章

重置 ASP.NET 密码 - 安全问题?

asp.net生成四位数的随机数,并且保证48小时内不会重复

密码保护 IIS 7.5 中的 ASP.NET Web 应用程序

ASP.NET Membership 是不是具有生成密码重置 URL 的机制?

如何从 ASP.NET Core 中的密码重置令牌中检索用户?

使用 ASP.NET 身份重置密码时令牌无效

(c)2006-2024 SYSTEM All Rights Reserved IT常识