c#验证码的生成
一:方法一
1.新建一个一般处理程序文件 2 /// <summary> 3 /// 验证码 4 /// </summary> 5 public class ValidateImage : IHttpHandler, IRequiresSessionState 6 { 7 int intLength = 4; //长度 8 string strIdentify = "IdentifyCode"; //随机字串存储键值,以便存储到Session中 9 10 public ValidateImage() 11 { 12 } 13 14 /// <summary> 15 /// 生成验证图片核心代码 16 /// </summary> 17 /// <param name="hc"></param> 18 public void ProcessRequest(HttpContext hc) 19 { 20 //设置输出流图片格式 21 if (hc.Session["valcode"]!=null){ 22 hc.Session["valcode"] = null; 23 } 24 hc.Response.ContentType = "image/gif"; 25 Bitmap b = new Bitmap(70, 30); 26 Graphics g = Graphics.FromImage(b); 27 g.FillRectangle(new SolidBrush(Color.YellowGreen), 0, 0, 70, 30); 28 Font font = new Font(FontFamily.GenericSerif, 24, FontStyle.Bold, GraphicsUnit.Pixel); 29 Random r = new Random(); 30 31 //合法随机显示字符列表 32 string strLetters = "1234567890";// "abcdefghijklmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ23456789"; 33 StringBuilder s = new StringBuilder(); 34 35 //将随机生成的字符串绘制到图片上 36 for (int i = 0; i < intLength; i++) 37 { 38 s.Append(strLetters.Substring(r.Next(0, strLetters.Length - 1), 1)); 39 g.DrawString(s[s.Length - 1].ToString(), font, new SolidBrush(Color.Blue), i * 15, r.Next(0, 8)); 40 } 41 42 ////生成干扰线条 43 Pen pen = new Pen(new SolidBrush(Color.Blue), 2); 44 for (int i = 0; i < 5; i++) 45 { 46 g.DrawLine(pen, new Point(r.Next(0, 100), r.Next(0, 59)), new Point(r.Next(0, 199), r.Next(0, 59))); 47 } 48 b.Save(hc.Response.OutputStream, ImageFormat.Gif); 49 // hc.Session[strIdentify] = s.ToString(); //先保存在Session中,验证与用户输入是否一致 50 Chain.Common.ValCodeModel CMVc = new Chain.Common.ValCodeModel(); 51 CMVc.valCode = s.ToString(); 52 CMVc.Failure = 3 * 60; 53 CMVc.CreateDate = DateTime.Now; 54 hc.Session["valcode"] = CMVc; 55 //hc.Response.SetCookie(new HttpCookie("identifyCode", s.ToString())); 56 hc.Response.End(); 57 58 } 59 60 /// <summary> 61 /// 表示此类实例是否可以被多个请求共用(重用可以提高性能) 62 /// </summary> 63 public bool IsReusable 64 { 65 get 66 { 67 return true; 68 } 69 } 70 }
2.页面显示验证码处理:
<div class="check"> <a href="javascript:void(0);" onclick="javascript:Login_ChangeValImg();"> <img id="Login_ValImg" src="" style="height: 30px; width: 90px; border: 0" alt="" title="看不清?换一个" align="top" /></a> </div>
3.js页面处理
1 $(document).ready(function () { 2 Login_ChangeValImg(); 3 }); 4 function Login_ChangeValImg() { 5 /*自动刷新验证码*/ 6 ChangeValImg(); 7 setTimeout("Login_ChangeValImg()", 10 * 60 * 1000); 8 } 9 10 function ChangeValImg() { 11 $("#Login_ValImg").attr("src", "Service/ValidateImage.ashx?" + GetGuid()); 12 $("#txtValCode").val(""); 13 }