.net生成验证码

本文为大家分享了.net生成验证码所有代码,大家可以动手操作一下,会有意想不到的收获。

先给大家看看效果图:

页面代码:

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
  <title>验证码</title>
  <script type="text/javascript">
    //换一张
    function change() {
      var img = document.getElementById("ValidateCode");
      img.src = img.src + '?';
    }
  </script>
</head>
<body>
  <form id="form1" runat="server">
  <div>
    <table>
      <tr>
        <th>
          验证码
        </th>
        <td>
          <asp:TextBox runat="server" ID="tbCheckCode" CssClass="Small" MaxLength="4"></asp:TextBox>
        </td>
        <td>
          <img src="VerifyCode.aspx" id="ValidateCode" alt="换一张" onclick="javascript:change()" />
        </td>
        <td>
          <a id="ChangeCode" href="#" onclick="javascript:change()">换一张</a>
        </td>
      </tr>
      <tr>
        <td>
          <asp:Button runat="server" ID="LoginSubmit" OnClick="LoginSubmits" Text="登录" />
        </td>
      </tr>
    </table>
  </div>
  </form>
</body>
</html>

后台代码:

    /// <summary>
    /// 登录
    /// </summary>
    /// <param name="sender"></param>
    protected void LoginSubmits(object sender, EventArgs e)
    {
      CheckLogin();
    }

    #region 私有方法
    #region
    public static Boolean IsNotNull(Object str)
    {
      return !IsNull(str);
    }
    public static Boolean IsNull(Object str)
    {
      return str == null;
    }
    public static void Show(System.Web.UI.Page page, string msg)
    {
      page.ClientScript.RegisterStartupScript(page.GetType(), "message",
        "<script language='javascript' defer>alert('" + msg.ToString() + "');</script>");
    }
    #endregion

    private void CheckLogin()
    {
      if (tbCheckCode.Text.Trim() == "")
      {
        Show(this, "验证码不能为空!");
        return;
      }
      else
      {
        if (IsNotNull(Session["ValidateCheckCode"]))
        {
          if (tbCheckCode.Text.Trim() != Session["ValidateCheckCode"].ToString())
          {
            Show(this, "验证码填写不正确!");
            tbCheckCode.Text = "";
            return;
          }
        }
        else
        {
          Show(this, "请刷新验证码!");
          return;
        }
      }
    }
    #endregion
  }
}

生成验证码:

using System;
using System.Drawing;
using System.Text;
using System.Web;

namespace Web.TEXT
{
  public partial class VerifyCode : System.Web.UI.Page
  {
    public Encoding GB = Encoding.GetEncoding("GB2312");

    protected void Page_Load(object sender, EventArgs e)
    {
      VerifyCode v = new VerifyCode();

      v.Length = this.length;
      v.FontSize = this.fontSize;
      v.Chaos = this.chaos;
      v.BackgroundColor = this.backgroundColor;
      v.ChaosColor = this.chaosColor;
      v.CodeSerial = this.codeSerial;
      v.Colors = this.colors;
      v.Fonts = this.fonts;
      v.Padding = this.padding;
      string code = v.CreateVerifyCode(); //取随机码
      v.CreateImageOnPage(code, this.Context); // 输出图片
      Response.Cookies.Add(new HttpCookie("CheckCode", code.ToUpper())); // 使用Cookies取验证码的值

      System.Web.HttpContext.Current.Session["ValidateCheckCode"] = code;
      //return checkCode;
    }

    #region 验证码长度(默认4个验证码的长度)

    private int length = 4; 

    public int Length
    {
      get { return length; }
      set { length = value; }
    }

    #endregion

    #region 验证码字体大小(为了显示扭曲效果,默认40像素,可以自行修改)

    private int fontSize = 12;

    public int FontSize
    {
      get { return fontSize; }
      set { fontSize = value; }
    }

    #endregion

    #region 边框补(默认1像素)

    private int padding = 1;

    public int Padding
    {
      get { return padding; }
      set { padding = value; }
    }

    #endregion

    #region 是否输出燥点(默认不输出)

    private bool chaos = true;

    public bool Chaos
    {
      get { return chaos; }
      set { chaos = value; }
    }

    #endregion

    #region 输出燥点的颜色(默认灰色)

    private Color chaosColor = Color.LightGray;

    public Color ChaosColor
    {
      get { return chaosColor; }
      set { chaosColor = value; }
    }

    #endregion

    #region 自定义背景色(默认白色)

    private Color backgroundColor = Color.White;

    public Color BackgroundColor
    {
      get { return backgroundColor; }
      set { backgroundColor = value; }
    }

    #endregion

    #region 自定义随机颜色数组

    private Color[] colors =
    {
      Color.Black, Color.Red, Color.DarkBlue, Color.Green, Color.Orange, Color.Brown,
      Color.DarkCyan, Color.Purple
    };

    public Color[] Colors
    {
      get { return colors; }
      set { colors = value; }
    }

    #endregion

    #region 自定义字体数组

    private string[] fonts = {"Arial", "Georgia"};

    public string[] Fonts
    {
      get { return fonts; }
      set { fonts = value; }
    }

    #endregion

    #region 自定义随机码字符串序列(使用逗号分隔)

    private string codeSerial = "0,1,2,3,4,5,6,7,8,9";
    // string codeSerial = "0,1,2,3,4,5,6,7,8,9,a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u,v,w,x,y,z,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P,Q,R,S,T,U,V,W,X,Y,Z";
    // string codeSerial = "殃,央,鸯,秧,杨,扬,佯,疡,羊,洋,阳,氧,仰,痒,养,样,漾,邀,腰,妖,瑶,摇,尧,遥,窑,谣,姚,咬,舀,药,要,耀,椰,噎,耶,爷,野,冶,也,页,掖,业,叶,曳,腋,夜,液,一,壹,医,揖,铱,依,伊,衣,颐,夷,遗,移,仪,胰,疑,沂,宜,姨,彝,椅,蚁,倚,已,乙,矣,以,艺,抑,易,邑,屹,亿,役,臆,逸,肄,疫,亦,裔,意,毅,忆,义,益,溢,诣,议,谊,译,异,翼,翌,绎,茵,荫,因,殷,音,阴,姻,吟,银,淫,寅,饮,尹,引,隐,印,英,樱,婴,鹰,应,缨,莹,萤,营,荧,蝇,迎,赢,盈,影,颖,硬,映,哟,拥,佣,臃,痈,庸,雍,踊,蛹,咏,泳,涌,永,恿,勇,用,幽,优,悠,忧,尤,由,邮,铀,犹,油,游,酉,有,友,右,佑,釉,诱,又,幼,迂,淤,于,盂,榆,虞,愚,舆,余,俞,逾,鱼,愉,渝,渔,隅,予,娱,雨,与,屿,禹,株,蛛,朱,猪,诸,诛,逐,竹,烛,煮,拄,瞩,嘱,主,著,柱,助,蛀,贮,铸,筑,住,注,祝,驻,抓,爪,拽,专,砖,转,撰,赚,篆,桩,庄,装,妆,撞,壮,状,椎,锥,追,赘,坠,缀,谆,准,捉,拙,卓,桌,琢,茁,酌,啄,着,灼,浊,兹,咨,资,姿,滋,淄,孜,紫,仔,籽,滓,子,自,渍,字,鬃,棕,踪,宗,综,总,纵,邹,走,奏,揍,租,足,卒,族,祖,诅,阻,组,钻,纂,嘴,醉,最,罪,尊,遵,昨,左,佐,柞,做,作,坐,座";
    public string CodeSerial
    {
      get { return codeSerial; }
      set { codeSerial = value; }
    }

    #endregion

    //产生波形滤镜效果

    #region 产生波形滤镜效果

    private const double PI = 3.1415926535897932384626433832795;
    private const double PI2 = 6.283185307179586476925286766559;

    /**/

    /// <summary>
    /// 正弦曲线Wave扭曲图片(Edit By 51aspx.com)
    /// </summary>
    /// <param name="srcBmp">图片路径</param>
    /// <param name="bXDir">如果扭曲则选择为True</param>
    /// <param name="nMultValue">波形的幅度倍数,越大扭曲的程度越高,一般为3</param>
    /// <param name="dPhase">波形的起始相位,取值区间[0-2*PI)</param>
    /// <returns></returns>
    public System.Drawing.Bitmap TwistImage(Bitmap srcBmp, bool bXDir, double dMultValue, double dPhase)
    {
      System.Drawing.Bitmap destBmp = new Bitmap(srcBmp.Width, srcBmp.Height);

      // 将位图背景填充为白色
      System.Drawing.Graphics graph = System.Drawing.Graphics.FromImage(destBmp);
      graph.FillRectangle(new SolidBrush(System.Drawing.Color.White), 0, 0, destBmp.Width, destBmp.Height);
      graph.Dispose();

      double dBaseAxisLen = bXDir ? (double) destBmp.Height : (double) destBmp.Width;

      for (int i = 0; i < destBmp.Width; i++)
      {
        for (int j = 0; j < destBmp.Height; j++)
        {
          double dx = 0;
          dx = bXDir ? (PI2*(double) j)/dBaseAxisLen : (PI2*(double) i)/dBaseAxisLen;
          dx += dPhase;
          double dy = Math.Sin(dx);

          // 取得当前点的颜色
          int nOldX = 0, nOldY = 0;
          nOldX = bXDir ? i + (int) (dy*dMultValue) : i;
          nOldY = bXDir ? j : j + (int) (dy*dMultValue);

          System.Drawing.Color color = srcBmp.GetPixel(i, j);
          if (nOldX >= 0 && nOldX < destBmp.Width
            && nOldY >= 0 && nOldY < destBmp.Height)
          {
            destBmp.SetPixel(nOldX, nOldY, color);
          }
        }
      }

      return destBmp;
    }

    #endregion

    #region 生成校验码图片

    public Bitmap CreateImageCode(string code)
    {
      int fSize = FontSize;
      int fWidth = fSize + Padding;

      int imageWidth = (int) (code.Length*fWidth) + 4 + Padding*2;
      int imageHeight = fSize*2 + Padding;

      System.Drawing.Bitmap image = new System.Drawing.Bitmap(imageWidth, imageHeight);

      Graphics g = Graphics.FromImage(image);

      g.Clear(BackgroundColor);

      Random rand = new Random();

      //给背景添加随机生成的燥点
      if (this.Chaos)
      {

        Pen pen = new Pen(ChaosColor, 0);
        int c = Length*10;

        for (int i = 0; i < c; i++)
        {
          int x = rand.Next(image.Width);
          int y = rand.Next(image.Height);

          g.DrawRectangle(pen, x, y, 1, 1);
        }
      }

      int left = 0, top = 0, top1 = 1, top2 = 1;

      int n1 = (imageHeight - FontSize - Padding*2);
      int n2 = n1/4;
      top1 = n2;
      top2 = n2*2;

      Font f;
      Brush b;

      int cindex, findex;

      #region 随机字体和颜色的验证码字符

      for (int i = 0; i < code.Length; i++)
      {
        cindex = rand.Next(Colors.Length - 1);
        findex = rand.Next(Fonts.Length - 1);

        f = new System.Drawing.Font(Fonts[findex], fSize, System.Drawing.FontStyle.Bold);
        b = new System.Drawing.SolidBrush(Colors[cindex]);

        if (i%2 == 1)
        {
          top = top2;
        }
        else
        {
          top = top1;
        }

        left = i*fWidth;

        g.DrawString(code.Substring(i, 1), f, b, left, top);
      }

      //画一个边框 边框颜色为Color.Gainsboro
      g.DrawRectangle(new Pen(Color.Gainsboro, 0), 0, 0, image.Width - 1, image.Height - 1);
      g.Dispose();

      //产生波形
      //image = TwistImage(image, true, 8, 4);

      return image;
    }

    #endregion

    //将创建好的图片输出到页面
    public void CreateImageOnPage(string code, HttpContext context)
    {
      System.IO.MemoryStream ms = new System.IO.MemoryStream();
      Bitmap image = this.CreateImageCode(code);

      image.Save(ms, System.Drawing.Imaging.ImageFormat.Jpeg);

      context.Response.ClearContent();
      context.Response.ContentType = "image/Jpeg";
      context.Response.BinaryWrite(ms.GetBuffer());

      ms.Close();
      ms = null;
      image.Dispose();
      image = null;
    }

    #endregion

    #region 生成随机字符码

    public string CreateVerifyCode(int codeLen)
    {
      if (codeLen == 0)
      {
        codeLen = Length;
      }

      string[] arr = CodeSerial.Split(',');

      string code = "";

      int randValue = -1;

      Random rand = new Random(unchecked((int) DateTime.Now.Ticks));

      for (int i = 0; i < codeLen; i++)
      {
        randValue = rand.Next(0, arr.Length - 1);

        code += arr[randValue];
      }

      return code;
    }

    public string CreateVerifyCode()
    {
      return CreateVerifyCode(0);
    }

    #endregion
  }
}

是不是很有成就感,为大家分享的代码很完整,大家可以在这个基础进行扩展,希望大家喜欢。

(0)

相关推荐

  • ASP.NET验证码实现(附源码)

    首先看下效果实现(由于gif屏幕录制软件是即时找的,有些失祯) 代码主要就是绘制验证码类的实现 using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Drawing; using System.IO; namespace SecurityCodePic { public class DrawingSecurityCode { /// <summary>

  • asp.net登录验证码实现方法

    前端添加的标签和方法: 验证码: 复制代码 代码如下: <input id="txtVerifyCode" type="text" maxlength="5" style="line-height: 30px;  height: 30px; width: 80px;border:solid 1px #d4d4d4;" class="input"/>&nbsp<img src=&qu

  • asp.net验证码的简单制作

    实际上关于asp.net验证码制作的文章已经很多很多了,但是今天还是要和大家继续分享,亲,可以综合几篇实例,编写出适用于自己网站的ASP.NET验证码,大概也就两大部分: 先建立一个asp.net窗体ValidateCode.aspx:不写任何东西.直接在后台ValidateCode.aspx.cs中写如下代码: protected void Page_Load(object sender, EventArgs e) { string validateCode = CreateValidateC

  • MVC使用极验验证制作登录验证码学习笔记7

    在之前的项目中,如果有需要使用验证码,基本都是自己用GDI+画图出来,简单好用,但是却也存在了一些小问题,首先若较少干扰线,则安全性不是很高,验证码容易被机器识别,若多画太多干扰线条,机器人识别率下降的同时,人眼的识别率也同步下降(震惊哭).更为重要的是,GDI+绘制的验证码一般来说也不会很美观,如果做一个炫酷的登陆界面却配了这样一个验证码,画风诡异,丑到极致. 再后来浏览网页的过程中,发现很多很多网站项目中都使用了一种叫极验验证的验证码,采用移动滑块的方式进行验证,方便美观.而一番搜索之后了解

  • 深入学习.net验证码生成及使用方法

    小课堂:验证码的作用: 几年前,大部分网站.论坛之类的是没有验证码的,因为对于一般用户来说验证码只是增加了用户的操作,降低了用户的体验.但是后来各种灌水机器人.投票机器人.恶意注册机器人层出不穷,大大增加了网站的负担同时也给网站数据库带来了大量的垃圾数据.为了防止各种机器人程序的破坏,于是程序员想出了只有人眼能够识别的,程序不容易识别的验证码! 验证码是一个图片,将字母.数字甚至汉字作为图片的内容,这样一张图片中的内容用人眼很容易识别,而程序将无法识别.在进行数据库操作之前(比如登录验证.投票.

  • 详解ASP.NET验证码的生成方法

    一般验证码的生成方法都是相同的,主要的步骤都有两步 第一步:随机出一系统验证码的数字或字母,顺便把随机生成的数字或字母写入Cookies 或者 Session. 第二步:用第一步随机出来的数字或字母来合成图片. 可以看出来验证码的复杂度主要是第二步来完成,你可以根据自己所要的复杂度来设定. 我们一起来看看:  第一步:随机生成数字或字母的方法 /// <summary> /// 生成验证码的随机数 /// </summary> /// <returns>返回五位随机数&

  • asp.net简单生成验证码的方法

    本文实例讲述了asp.net简单生成验证码的方法.分享给大家供大家参考,具体如下: 1.新建一个一般处理程序 namespace WebApplication1 { /// <summary> /// $codebehindclassname$ 的摘要说明 /// </summary> [WebService(Namespace = "http://tempuri.org/")] [WebServiceBinding(ConformsTo = WsiProfil

  • ASP.NET验证码(3种)

    日常生活中我们在使用网站时都会遇到验证码,大家有没有想过为什么要使用验证码? 其实验证码的作用就是防止恶意破解密码.刷票.论坛灌水.刷页.有效防止某个黑客对某一个特定注册用户用特定程序暴力破解方式进行不断的登录尝试.今天就跟大家分享ASP.NET的三种验证码. 1.GSC_WebControlLibrary 这是在网上找到的一个控件,非常好用.但是效果不是特别好(见下图. )虽然容易使用,所有的属性都可以像控件一样设置,但是可用性不太高.用户不能自定义,而且看起来这个验证码效果不太好. 效果:

  • 12306动态验证码启发之ASP.NET实现动态GIF验证码(附源码)

    12306网站推出"彩色动态验证码机制",新版验证码不但经常出现字符叠压,还不停抖动,不少人大呼"看不清",称"那个验证码,是毕加索的抽象画么!"铁总客服则表示:为了能正常购票只能这样.而多家抢票软件接近"报废",引发不少网友不满的吐槽称"太抽象太艺术了". 以前做项目有时候也会用到验证码,但基本都是静态的,这次也想凑凑12306的热闹.闲言少续,切入正题,先上代码. 实现方法: public void S

  • asp.net生成字母和数字混合图形验证码

    验证码技术是网站开发过程中比较重要的技术,可以防止非法人员利用注册机或者登陆工具来攻击我们的网站.下面是效果图: 具体实现方法如下: 1.主要思路是:引用Using System.Drawing命名空间,利用Graphics的FromImage方法创建一个画布,同时设置画布的宽和高,然后通过Graphics类 的DrawString方法随机生成的字符串绘制到画布中,绘制验证码的同时,在画布中利用SetPixel方法绘制一些色点,从而防止非法人员利用机器 人来进行登陆.当我们绘制验证码完毕后,在需

随机推荐