好了今天我们在做一个验证码控件.
首先先说要做的是什么我们要做的一个控件,可以从工具栏拖出来的那种.验证码控件首先想到的是什么,好吧.我首先想到的是Image服务器控件。所以就先继承image开始吧。首先创建一个类库项目,添加一个CodeControls类然后让他继承image。然后给他一个Text属性,代表这个控件验证码的值。
public virtual string Text
{
}
然后呢,要使得页面获得这个验证码,使验证码在浏览器中显示。我们要重新它的ImageUrl属性
public override string ImageUrl
{
}
怎么得到这个ImageUrl呢,我是这么个思路,没刷新一次在服务器端就生成一张验证码的图片然后用这个imageurl引用这个图片的路径。
img.Save(System.AppDomain.CurrentDomain.BaseDirectory + "\\hehe.bmp");
return System.AppDomain.CurrentDomain.BaseDirectory + "hehe.bmp";
然后用Imageurl引用这个图片路径因为image控件是利用的相对路径所以
public override string ImageUrl
{
get {
return
"hehe.bmp";
}
}
然后就是Text这个简单在生成验证码的时候赋值给一个全局字段就可以。
然后我想让这个验证码点击之后刷新,实现image点击事件的话就让它继承
IPostBackEventHandler接口 实现接口之后给click事件注册生成验证码图片的方法。好吧,该说的也就这么多这只是个很简单的验证码控件,更多的是让大家熟悉自定义控件的应用。现在给出源代码
using System;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.ComponentModel;
using System.IO;
using System.Drawing;
using System.Drawing.Drawing2D;
namespace CustomComponents
{
public class CodeControls : System.Web.UI.WebControls.Image, IPostBackEventHandler
{
public string strCode = "";
public virtual string Text
{
get
{
return strCode;
}
}
public CodeControls()
{
Click += new System.EventHandler(Rersh);
CreateImg();
}
public override string ImageUrl
{
get {
return
"hehe.bmp";
}
}
private static readonly object ClickKey = new object();
public event EventHandler Click
{
add
{
Events.AddHandler(ClickKey, value);
}
remove
{
Events.RemoveHandler(ClickKey, value);
}
}
protected virtual void OnClick(EventArgs e)
{
EventHandler clickEventDelegate =
(EventHandler)Events[ClickKey];
if (clickEventDelegate != null)
{
clickEventDelegate(this, e);
}
}
protected override void AddAttributesToRender(HtmlTextWriter writer)
{
base.AddAttributesToRender(writer);
writer.AddAttribute(HtmlTextWriterAttribute.Onclick, Page.ClientScript.GetPostBackEventReference(this, "OnClick"));
}
public void RaisePostBackEvent(string argument)
{
OnClick(EventArgs.Empty);
}
private string MakeCode(int codeLen)
{
if (codeLen < 1)
{
return string.Empty;
}
int number;
string checkCode = string.Empty;
Random random = new Random();
for (int index = 0; index < codeLen; index++)
{
number = random.Next();
if (number % 2 == 0)
{
checkCode += (char)('0' + (char)(number % 10)); //生成数字
}
else
{
checkCode += (char)('A' + (char)(number % 26)); //生成字母
}
}
return checkCode;
}
private MemoryStream CreateCodeImg(string checkCode)
{
if (string.IsNullOrEmpty(checkCode))
{
return null;
}
Bitmap image = new Bitmap((int)Math.Ceiling((checkCode.Length * 12.5)), 22);
Graphics graphic = Graphics.FromImage(image);
try
{
Random random = new Random();
graphic.Clear(Color.White);
int x1 = 0, y1 = 0, x2 = 0, y2 = 0;
for (int index = 0; index < 25; index++)
{
x1 = random.Next(image.Width);
x2 = random.Next(image.Width);
y1 = random.Next(image.Height);
y2 = random.Next(image.Height);
graphic.DrawLine(new Pen(Color.Silver), x1, y1, x2, y2);
}
Font font = new Font("Arial", 12, (FontStyle.Bold | FontStyle.Italic));
LinearGradientBrush brush = new LinearGradientBrush(new Rectangle(0, 0, image.Width, image.Height), Color.Red, Color.DarkRed, 1.2f, true);
graphic.DrawString(checkCode, font, brush, 2, 2);
int x = 0;
int y = 0;
//画图片的前景噪音点
for (int i = 0; i < 100; i++)
{
x = random.Next(image.Width);
y = random.Next(image.Height);
image.SetPixel(x, y, Color.FromArgb(random.Next()));
}
//画图片的边框线
graphic.DrawRectangle(new Pen(Color.Silver), 0, 0, image.Width - 1, image.Height - 1);
//将图片验证码保存为流Stream返回
System.IO.MemoryStream ms = new System.IO.MemoryStream();
image.Save(ms, System.Drawing.Imaging.ImageFormat.Gif);
return ms;
}
finally
{
graphic.Dispose();
image.Dispose();
}
}
private string CreateImg()
{
strCode = MakeCode(4);
Stream ms = CreateCodeImg(strCode);
System.Drawing.Image img = System.Drawing.Image.FromStream(ms);
img.Save(System.AppDomain.CurrentDomain.BaseDirectory + "\\hehe.bmp");
return System.AppDomain.CurrentDomain.BaseDirectory + "hehe.bmp";
}
private void Rersh(object sender, EventArgs e)
{
CreateImg();
}
}
}
生成验证码的代码参考的网上的代码本文主要是让大家了解自定义控件的应用,新建一个网站项目引用这个类库即可。