当前位置: 首页 > 图文教程 > 网络编程 > ASP.NET > asp.net如何生成图片验证码(简单)

ASP.NET
Visual Studio.Net 内幕(7)
.Net 2.0 原汁原味读取注册表
ASP.NET 2.0中预设的cookie
ASP.NET:一段比较经典的多线程学习代码
ASP.NET2.0服务器控件之自定义状态管理
Asp.net给站点某目录增加Aspnet用户
ASP.NET技巧:请求网址并解析返回的html
在Asp.net用C#建立动态Excel
ASP.NET2.0:页面中链入的CSS、js文件带中文时需注意
ASP.NET技巧:数据岛出到Excel最为简易的方法
第一次用.net2.0 LOGIN登陆控件的困惑和解决方法
在ASP.net中保存/取出图片入/从SQL数据库
ASP.NET技巧:做个DataList可分页的数据源
在.NET中利用委托实现窗体间通信
在.NET2.0中使用自定义事务操作
解决 ASP.NET中目录访问权限的问题
ASP.Net防止刷新自动触发事件的解决方案
白刃之战:PHP vs. ASP.NET(节选)-架构比较
C#中使用SendMessage
提取HTML代码中文字的C#函数

ASP.NET 中的 asp.net如何生成图片验证码(简单)


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-08-14   浏览: 147 ::
收藏到网摘: n/a

新建一个页面image.aspx,添加命名空间:

usingSystem.Drawing.Imaging;
usingSystem.IO;

然后在Page_load事件拷入如下代码:

//生成4位的验证码
stringtmp=RndNum(4);
HttpCookiea=newHttpCookie("ImageV",tmp);
Response.Cookies.Add(a);
this.ValidateCode(tmp);

接下来向该页面添加两个方法:

privatevoidValidateCode(stringVNum)
{
BitmapImg=null;
Graphicsg=null;
MemoryStreamms=null;

intgheight=VNum.Length*12;
Img=newBitmap(gheight,25);
g=Graphics.FromImage(Img);
//背景颜色
g.Clear(Color.White);
//文字字体
Fontf=newFont("ArialBlack",10);
//文字颜色
SolidBrushs=newSolidBrush(Color.Black);
g.DrawString(VNum,f,s,3,3);
ms=newMemoryStream();
Img.Save(ms,ImageFormat.Jpeg);
Response.ClearContent();
Response.ContentType="image/Jpeg";
Response.BinaryWrite(ms.ToArray());

g.Dispose();
Img.Dispose();
Response.End();
}

privatestringRndNum(intVcodeNum)
{
stringVchar="0,1,2,3,4,5,6,7,8,9,a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p"+
",q,r,s,t,u,v,w,x,y,z";
string[]VcArray=Vchar.Split(newChar[]{','});
stringVNum="";
inttemp=-1;

Randomrand=newRandom();

for(inti=1;i<VcodeNum+1;i++)
{
if(temp!=-1)
{
rand=newRandom(i*temp*unchecked((int)DateTime.Now.Ticks));
}

intt=rand.Next(35);
if(temp!=-1&&temp==t)
{
returnRndNum(VcodeNum);
}
temp=t;
VNum+=VcArray[t];
}
returnVNum;
}

如果要在页面a.aspx生成验证码,则在该页面添加一个图片控件,假设命名为:ImageButton1,然后在page_Load事件中写如下代码:

ImageButton1.ImageUrl="image.aspx";

这样就可以生成验证码了,image.aspx页面可以随便放在哪里,不过要注意ImageButton1.ImageUrl要写对,同级可以直接写image.aspx,上一级写../image.aspx,很方便吧。