asp.net 验证码类

我们在设计用户登录模块时,经常会用到验证码,可以有效地防止黑客软件的恶意破解,现公开我常用的验证码的源代码,生成效果如图:

/**/ ///<summary>
///验证码模块
///</summary>

publicclassCreateImage
... {
publicstaticvoidDrawImage()
...{
CreateImageimg
=newCreateImage();
HttpContext.Current.Session[
"CheckCode"]=img.RndNum(4);
img.CreateImages(HttpContext.Current.Session[
"CheckCode"].ToString());
}


/**////<summary>
///生成验证图片
///</summary>
///<paramname="checkCode">验证字符</param>

privatevoidCreateImages(stringcheckCode)
...{
intiwidth=(int)(checkCode.Length*13);
System.Drawing.Bitmapimage
=newSystem.Drawing.Bitmap(iwidth,23);
Graphicsg
=Graphics.FromImage(image);
g.Clear(Color.White);
//定义颜色
Color[]c=...{Color.Black,Color.Red,Color.DarkBlue,Color.Green,Color.Orange,Color.Brown,Color.DarkCyan,Color.Purple};
//定义字体
string[]font=...{"Verdana","MicrosoftSansSerif","ComicSansMS","Arial","宋体"};
Randomrand
=newRandom();
//随机输出噪点
for(inti=0;i<50;i++)
...{
intx=rand.Next(image.Width);
inty=rand.Next(image.Height);
g.DrawRectangle(
newPen(Color.LightGray,0),x,y,1,1);
}


//输出不同字体和颜色的验证码字符
for(inti=0;i<checkCode.Length;i++)
...{
intcindex=rand.Next(7);
intfindex=rand.Next(5);

Fontf
=newSystem.Drawing.Font(font[findex],10,System.Drawing.FontStyle.Bold);
Brushb
=newSystem.Drawing.SolidBrush(c[cindex]);
intii=4;
if((i+1)%2==0)
...{
ii
=2;
}

g.DrawString(checkCode.Substring(i,
1),f,b,3+(i*12),ii);
}

//画一个边框
g.DrawRectangle(newPen(Color.Black,0),0,0,image.Width-1,image.Height-1);

//输出到浏览器
System.IO.MemoryStreamms=newSystem.IO.MemoryStream();
image.Save(ms,System.Drawing.Imaging.ImageFormat.Jpeg);
HttpContext.Current.Response.ClearContent();
//Response.ClearContent();
HttpContext.Current.Response.ContentType="image/Jpeg";
HttpContext.Current.Response.BinaryWrite(ms.ToArray());
g.Dispose();
image.Dispose();
}


/**////<summary>
///生成随机的字母
///</summary>
///<paramname="VcodeNum">生成字母的个数</param>
///<returns>string</returns>

privatestringRndNum(intVcodeNum)
...{
stringVchar="0,1,2,3,4,5,6,7,8,9";
string[]VcArray=Vchar.Split(',');
stringVNum="";//由于字符串很短,就不用StringBuilder了
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(VcArray.Length);
if(temp!=-1&&temp==t)
...{
returnRndNum(VcodeNum);
}

temp
=t;
VNum
+=VcArray[t];
}

returnVNum;
}

}

使用方法:
1
、在 Web 项目中添加一个类,如 “CreateImage.cs” ,然后将我公布的源代码 Copy 进去;
2
、再新建一个 Web 窗体,如 “Image.aspx” ,在 Page_Load 中加入代码 “CreateImage.DrawImage ();” 当然别忘了加上对类的引用哦!!
3
、在页面的合适位置上(你想放验证码的位置)上加上如下 javascript 代码就 OK 了,
<SCRIPT LANGUAGE="JavaScript">
<!--
var numkey = Math.random();
numkey
= Math.round(numkey*10000);
document.write("<img src=\"Image.aspx?k="
+ numkey + "\" width=\"52\" height=\"23\" hspace=\"4\"");
//-->
</SCRIPT>

源代码如下:

你可能感兴趣的:(JavaScript,.net,算法,asp.net,asp)