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 }
ASP.NET短信登录验证码和图片验证程序源码可以使用以下代码实现。 短信验证码部分: ``` using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Web.UI; using System.Web.UI.WebControls; using System.Net; using System.Net.Mail; using System.Web.Services; public partial class SMSVerification : System.Web.UI.Page { protected void Page_Load(object sender, EventArgs e) { } [WebMethod] public static bool GenerateCode(string phone) { // 生成随机的4位验证码 Random rand = new Random(); int code = rand.Next(1000, 9999); // 发送验证码到手机号码 MailMessage message = new MailMessage(); SmtpClient smtpClient = new SmtpClient("smtp.gmail.com"); smtpClient.EnableSsl = true; message.From = new MailAddress("[email protected]"); message.To.Add(phone); message.Subject = "登录验证码"; message.Body = "验证码:" + code.ToString(); smtpClient.Send(message); return true; } } ``` 图片验证部分: ``` using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Web.UI; using System.Web.UI.WebControls; public partial class ImageVerification : System.Web.UI.Page { protected void Page_Load(object sender, EventArgs e) { if (!IsPostBack) { GenerateImageCode(); } } protected void btnSubmit_Click(object sender, EventArgs e) { if (txtCode.Text.Equals(Session["Code"].ToString(), StringComparison.OrdinalIgnoreCase)) { lblResult.Text = "验证码正确"; } else { lblResult.Text = "验证码错误"; GenerateImageCode(); } } private void GenerateImageCode() { string code = Guid.NewGuid().ToString().Substring(0, 6); Session["Code"] = code; Response.Clear(); Response.ContentType = "image/jpeg"; using (System.Drawing.Bitmap bitmap = new System.Drawing.Bitmap(100, 30)) { using (System.Drawing.Graphics g = System.Drawing.Graphics.FromImage(bitmap)) { g.FillRectangle(System.Drawing.Brushes.White, 0, 0, 100, 30); g.DrawString(code, new System.Drawing.Font(System.Drawing.FontFamily.GenericMonospace, 16), System.Drawing.Brushes.Black, 2, 2); } bitmap.Save(Response.OutputStream, System.Drawing.Imaging.ImageFormat.Jpeg); } Response.End(); } } ``` 以上是一个简单的ASP.NET短信登录验证码和图片验证程序的源码示例。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值