seanly

 

ASP.NET生成随机密码

public static string MakePassword(string pwdchars,int pwdlen)
{
string tmpstr="";
int iRandNum;
Random rnd=new Random();
for(inti=0; i{
iRandNum=rnd.Next(pwdchars.Length);
tmpstr+=pwdchars[iRandNum];
}
return tmpstr;
} 对照源码,讲一下具体的思路:

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

代码调用 MakePassword() 方法获取长度为 10 ,可用字符范围为大小写字母及数字的随机字符串。

string randomchars ="abcdefghijklmnopqrstuvwxyz0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";

string password = MakePassword(randomchars, 10); 以上是ASP.NET生成随机密码。

 

 

 

posted on 2010-08-30 15:12  seanly  阅读(170)  评论(0编辑  收藏  举报

导航