现在几乎所有的Web程序都提供了验证码功能,就比如我们常用的QQ、飞信、MSN来说,登陆的时候经常让我们输入验证码,同样为了安全在这个新闻系统中也提供了验证码输入。
初次用这个功能觉的会很难,学起来也不是很难,我们学的是如何应用,不过,如果让自己写这个功能还需要自习琢磨一下,里面需要一些简单的算法。
先列出具体实现,然后,在讲解不懂的地方。
1 在后台窗体上添加一个“一般处理程序”页,把如下代码复制到里面:
- <span style="font-size:18px;"><%@ WebHandler Language="C#" Class="WaterMark" %>
- using System;
- using System.Web;
- using System.Drawing;
- using System.Drawing.Drawing2D;
- using System.Web.SessionState;
-
- public class WaterMark : IHttpHandler, IRequiresSessionState
- {
-
-
-
-
- public void ProcessRequest(HttpContext context)
- {
-
- string checkCode = GenCode(5);
-
- context.Session["Code"] = checkCode;
-
- System.Drawing.Bitmap image = new System.Drawing.Bitmap(70, 22);
- Graphics g = Graphics.FromImage(image);
- try
- {
-
- Random random = new Random();
-
-
- g.Clear(Color.White);
-
-
- int i;
- for (i = 0; i < 25; i++)
- {
- int x1 = random.Next(image.Width);
- int x2 = random.Next(image.Width);
- int y1 = random.Next(image.Height);
- int y2 = random.Next(image.Height);
- g.DrawLine(new Pen(Color.Silver), x1, y1, x2, y2);
- }
-
- Font font = new System.Drawing.Font("Arial", 12, (System.Drawing.FontStyle.Bold));
- System.Drawing.Drawing2D.LinearGradientBrush brush = new System.Drawing.Drawing2D.LinearGradientBrush(new Rectangle(0, 0, image.Width, image.Height), Color.Blue, Color.DarkRed, 1.2F, true);
- g.DrawString(checkCode, font, brush, 2, 2);
-
-
- g.DrawRectangle(new Pen(Color.Silver), 0, 0, image.Width - 1, image.Height - 1);
- System.IO.MemoryStream ms = new System.IO.MemoryStream();
- image.Save(ms, System.Drawing.Imaging.ImageFormat.Gif);
- context.Response.ClearContent();
- context.Response.ContentType = "image/Gif";
- context.Response.BinaryWrite(ms.ToArray());
- }
- finally
- {
- g.Dispose();
- image.Dispose();
- }
- }
-
-
-
-
-
-
- private string GenCode(int num)
- {
- string str = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";
- char[] chastr = str.ToCharArray();
-
- string code = "";
- Random rd = new Random();
- int i;
- for (i = 0; i < num; i++)
- {
-
- code += str.Substring(rd.Next(0, str.Length), 1);
- }
- return code;
-
- }
-
- public bool IsReusable
- {
- get
- {
- return false;
- }
- }
-
- }</span>
2 在前台加入一个Image按钮,并设置ImageUrl,如下:
- <span style="font-size:18px;"><asp:Image runat="server" ID="tupian" CssClass="tu" ImageUrl="handler/WaterMark.ashx"/></span>
3 为了更完善,还需要加一个“单击”,更换验证码功能,可以加入一个<a></a>标签。如下:
- <span style="font-size:18px;"><a onclick="ChangeCode()" style="cursor:pointer">如果看不清,单击此处</a></span>
4 加入javascript 方法,ChangeCode来更换验证码:
- <span style="font-size:18px;"> <script language="javascript" type="text/javascript">
- function ChangeCode() {
- var imgNode = document.getElementById("vimg");
- <span style="font-size:18px;">
- <span style="font-size:18px;">imgNode.src = "handler/WaterMark.ashx?t=" + (new Date()).valueOf();
- }
- </script></span>
现在的效果图如下:
需要注意:步骤1 中Class=“”必须与添加类名一致,新添加的需手动更改,否则不能识别路径。
步骤3 ,如果使用Web端控件实现,则会出现网页“闪”的效果,因为单击一下,客户端需要向服务器提交一次数据。所以,我用的<a></a>标签。
虽然,实现了一个小功能完成了,但有些地方也不是很懂,还需要深入研究,继续完成……
出处: http://blog.csdn.net/lilongsheng1125/article/details/7834458