asp.net动态生成验证码

我们在设计用户登录模块时,经常会用到 验证码 ,可以有效地防止黑客软件的恶意破解,现公开我常用的验证码的源代码,
   使用方法:
   1、在Web项目中添加一个类,如“CreateImage.cs”,然后将我公布的源代码Copy进去;
   2、再新建一个Web窗体,如“Image. asp x”,在Page_Load中加入代码 “CreateImage.DrawImage ();”当然别忘了加上对类的引用哦!!
   3、在页面的合适位置上(你想放验证码的位置)上加上如下 java scr ip t代码就OK 了,
   
  
  源代码如下:   

  /// 
  /// 验证码模块
  /// 
  public class CreateImage
  {
  public static void DrawImage()
  {
  CreateImage img=new CreateImage();
  HttpContext.Current.session["CheckCode"]=img.RndNum(4);
  img.CreateImages(HttpContext.Current.Session["CheckCode"].ToString());
  }
  
  /// 
  /// 生成验证图片
  /// 
  /// 验证字符
  PRivate void CreateImages(string checkCode)
  {
  int iwidth = (int)(checkCode.Length * 13);
  System.Drawing.Bitmap image = new System.Drawing.Bitmap(iwidth, 23);
  Graphics g = 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","Microsoft Sans Serif","Comic Sans MS","Arial","宋体"};
  Random rand = new Random();
  //随机输出噪点
  for(int i=0;i<50;i++)
  {
  int x = rand.Next(image.Width);
  int y = rand.Next(image.Height);
  g.DrawRectangle(new Pen(Color.LightGray, 0),x,y,1,1);
  }
  
  //输出不同字体和颜色的验证码字符
  for(int i=0;i
  {
  int cindex = rand.Next(7);
  int findex = rand.Next(5);
  
  Font f = new System.Drawing.Font(font[findex], 10, System.Drawing.FontStyle.Bold);
  Brush b = new System.Drawing.SolidBrush(c[cindex]);
  int ii=4;
  if((i+1)%2==0)
  {
  ii=2;
  }
  g.DrawString(checkCode.Substring(i,1), f, b, 3+(i*12), ii);
  }
  //画一个边框
  g.DrawRectangle(new Pen(Color.Black,0),0,0,image.Width-1,image.Height-1);
  
  //输出到浏览器
  System.IO.MemoryStream ms = new System.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();
  }
  
  /// 
  /// 生成随机的字母
  /// 
  /// 生成字母的个数
  /// string
  private string RndNum(int VcodeNum) 
  {
  string Vchar = "0,1,2,3,4,5,6,7,8,9" ;
  string[] VcArray = Vchar.Split(',') ;
  string VNum = "" ; //由于字符串很短,就不用StringBuilder了
  int temp = -1 ; //记录上次随机数值,尽量避免生产几个一样的随机数
  
  //采用一个简单的算法以保证生成随机数的不同
  Random rand =new Random();
  for ( int i = 1 ; i < VcodeNum+1 ; i++ ) 
  { 
  if ( temp != -1) 
  {
  rand =new Random(i*temp*unchecked((int)DateTime.Now.Ticks));
  } 
  int t = rand.Next(VcArray.Length ) ;
  if (temp != -1 && temp == t) 
  {
  return RndNum( VcodeNum );
  }
  temp = t ;
  VNum += VcArray[t];
  }
  return VNum ;
  }
}


  • 6
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
public StringUnit() { // //TODO: 在此处添加构造函数逻辑 // } /// <summary> /// 生成随机数 /// </summary> /// <returns></returns> private string GenerateCheckCode() { #region int number; char code; string checkCode = String.Empty; System.Random random = new Random(); for (int i = 0; i < 5; i++) { number = random.Next(); if (number % 2 == 0) code = (char)('0' + (char)(number % 10)); else code = (char)('A' + (char)(number % 26)); checkCode += code.ToString(); } HttpContext.Current.Response.Cookies.Add(new HttpCookie("CheckCode", checkCode)); return checkCode; #endregion } /// <summary> /// 生成验证码图片 /// </summary> public void CreateCheckCodeImage() { #region string checkCode = GenerateCheckCode(); if (checkCode == null || checkCode.Trim() == String.Empty) return; System.Drawing.Bitmap image = new System.Drawing.Bitmap((int)Math.Ceiling((checkCode.Length * 12.5)), 22); Graphics g = Graphics.FromImage(image); try { //生成随机生成Random random = new Random(); //清空图片背景色 g.Clear(Color.White); //画图片的背景噪音线 for (int 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.FontStyle.Italic)); 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); //画图片的前景噪音点 for (int i = 0; i < 100; i++) { int x = random.Next(image.Width); int y = random.Next(image.Height); image.SetPixel(x, y, Color.FromArgb(random.Next())); } //画图片的边框线 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); HttpContext.Current.Response.ClearContent(); HttpContext.Current.Response.ContentType = "image/Gif"; HttpContext.Current.Response.BinaryWrite(ms.ToArray()); } finally { g.Dispose(); image.Dispose(); } #endregion }
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值