ASP.NET中的随机密码生成

发表于:2016-6-01 09:42

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:天启    来源:51Testing软件测试网原创

  第一种方法:
  用.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 长度的整数,以该数作为索引值,从可用字符串中随机取字符,以指定的密码长度为循环次数,依次连接取得的字符,最后即得到所需的随机密码串了。
《2023软件测试行业现状调查报告》独家发布~

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号