|
|
| ASP.net随机数应用实例(2) |
| 作者:不详 来源:不详 发布时间:2006-8-14 9:34:57 发布人:chinazhan |
减小字体
增大字体
是的,如你所见,产生了一样的两个随机数,无论重复多少次,都是一样的。原因在哪里呢? 不要以为使用系统时间作为随机种子就万无一失了——如果应用程序在一个较快的计算机上运行,则该计算机的系统时钟可能没有时间在此构造函数的调用之间进行更改,Random 的不同实例的种子值可能相同。这种情况下,我们就需要另外的算法来保证产生的数字的随机性。所以为了保证产生的随机数足够“随机”,我们不得不使用复杂一点的方法来获得随机种子。 在上面的这段程序中,我们首先使用系统时间作为随机种子,然后将上一次产生的随机数跟循环变量和一个与系统时间有关的整型参数相乘,以之作为随机种子,从而得到了每次都不同的随机种子,保证了产生足够“随机”的随机数。 得到整型的随机数组以后,我们将它变成字符串,然后使用System.Drawing中与GDI+相关的类生成一个图片并且在网页上显示出来。 生成图片的ASP.net页面全部代码如下: < %@ Page Language="C#" Debug="true" Trace="false" TraceMode="SortByCategory"% >< % @Import namespace="System.Drawing" % >< % @Import namespace="System.Drawing.Imaging" % >< % @Import namespace="System.Drawing.Text" % >< % @Import namespace="System.IO" % >< script language=C# runat=server > public void Page_Load(object sender,EventArgs e){ string strNum=GetRandomString(); string strFontName; int iFontSize; int iWidth; int iHeight; strFontName="宋体"; iFontSize=12; iWidth=10*strNum.Length; iHeight=25; Color bgColor=Color.Yellow; Color foreColor=Color.Red; Font foreFont=new Font(strFontName,iFontSize,FontStyle.Bold); Bitmap Pic=new Bitmap(iWidth,iHeight,PixelFormat.Format32bppArgb); Graphics g=Graphics.FromImage(Pic); Rectangle r=new Rectangle(0,0,iWidth,iHeight); g.FillRectangle(new SolidBrush(bgColor),r); g.DrawString(strNum,foreFont,new SolidBrush(foreColor),2,2); MemoryStream mStream=new MemoryStream(); Pic.Save(mStream,ImageFormat.Gif); g.Dispose(); Pic.Dispose(); Response.ClearContent(); Response.ContentType="image/GIF"; Response.BinaryWrite(mStream.ToArray()); Response.End(); } private int []GetRandomArray(int Length,int Up,int Down) { int iFirst=0; int []rtArray=new Int32[Length]; Random ro=new Random(Length*unchecked((int)DateTime.Now.Ticks)); iFirst=ro.Next(Up,Down); rtArray[0]=iFirst; for(int i=1;i< Length;i++) { Random ri=new Random(i*iFirst*unchecked((int)DateTime.Now.Ticks)); rtArray[i]=ri.Next(Up,Down); iFirst=rtArray[i]; } return rtArray; } 其中生成图片的部分相对复杂,但由于不是本文的主题所在,所以本文不对之做详细说明,有兴趣的读者可以参考杜亮编写的《亲密接触ASP.NET》一书中的相关内容。 最后我们可以编写一个普通的HTML页面来查看效果,只要把图片的src属性指向这个页面就行了(这里我们假设上面那个ASP.net文件的名字是“RandomPic.aspx”): < !DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" > < HTML > < HEAD > < TITLE > New Document < /TITLE > < META NAME="Generator" CONTENT="EditPlus" > < META NAME="Author" CONTENT="" > < META NAME="Keywords" CONTENT="" > < META NAME="Description" CONTENT="" > < /HEAD > < BODY > < img src="RandomPic.aspx" > < /BODY > < /HTML > 在笔者的机器上成功地看到了如下结果:  要实现像Chinaren网站那样的防恶意攻击的效果,只需要在留言簿的页面里产生随机数并且编写相应的JavaScript验证代码(事实上这个工作可以交给ASP.net的验证控件很容易地完成),然后传递到生成图片的页面里生成图片提示用户就可以了。 除此以外,随机数还有其它很多用途,特别是开发游戏的时候更是必不可少。到此,读者应该完全掌握在ASP.net中随机数的产生方法,如此,本文的目的也就达到了。 最后,有兴趣的读者可以试着解决这个问题: 在桥牌游戏中,发牌可以视作一个随机过程,但是后续过程受到前面的影响,即已经发出去的牌不可能再次发出。试编写一个程序模拟发牌过程。 要实现像Chinaren网站那样的防恶意攻击的效果,只需要在留言簿的页面里产生随机数并且编写相应的JavaScript验证代码(事实上这个工作可以交给ASP.net的验证控件很容易地完成),然后传递到生成图片的页面里生成图片提示用户就可以了。 除此以外,随机数还有其它很多用途,特别是开发游戏的时候更是必不可少。到此,读者应该完全掌握在ASP.net中随机数的产生方法,如此,本文的目的也就达到了。 最后,有兴趣的读者可以试着解决这个问题: 在桥牌游戏中,发牌可以视作一个随机过程,但是后续过程受到前面的影响,即已经发出去的牌不可能再次发出。试编写一个程序模拟发牌过程。 做人要厚道,请注明转自chinazhan中国站长(www.ChinaZhan.com)。
|
| |
|
[]
[返回上一页]
[打 印]
[收 藏] |
|
| ∷相关文章评论∷ (评论内容只代表网友观点,与本站立场无关!) [更多评论...] |
|
|