>  기사  >  백엔드 개발  >  12306 동적 인증 코드에서 영감을 받은 ASP.NET은 동적 GIF 인증 코드를 구현합니다.

12306 동적 인증 코드에서 영감을 받은 ASP.NET은 동적 GIF 인증 코드를 구현합니다.

高洛峰
高洛峰원래의
2017-01-13 15:28:501694검색

12306 웹사이트는 '다채로운 동적 인증 코드 메커니즘'을 출시했습니다. 새 버전의 인증 코드에는 종종 문자가 중복될 뿐만 아니라 많은 사람들이 명확하게 볼 수 없다고 소리쳤습니다. "저 인증코드는 피카소의 추상화입니다." 뭐!" 중국철도공사 고객센터는 "이것이야말로 정상적으로 티켓을 구매할 수 있는 유일한 방법이다"고 말했다. 많은 티켓 예매 소프트웨어가 폐기 위기에 처해 있으며, 많은 네티즌들은 “너무 추상적이고 예술적이다”라고 불만을 토로하고 있다.
과거에는 프로젝트를 할 때 인증번호가 가끔 사용되기도 했는데, 기본적으로는 정적인 편이었습니다. 이번에는 12306의 열기에 동참하고 싶었습니다. 더 이상 고민하지 않고 본론으로 들어가 코드부터 시작하겠습니다.

구현 방법 :

public void ShowCode()
   {
     //对象实例化
     Validate GifValidate = new Validate();
 
     #region 对验证码进行设置(不进行设置时,将以默认值生成)
     //验证码位数,不小于4位
     GifValidate.ValidateCodeCount = 4;
     //验证码字体型号(默认13)
     GifValidate.ValidateCodeSize = 13;
     //验证码图片高度,高度越大,字符的上下偏移量就越明显
     GifValidate.ImageHeight = 23;
     //验证码字符及线条颜色(需要参考颜色类)
     GifValidate.DrawColor = System.Drawing.Color.BlueViolet;
     //验证码字体(需要填写服务器安装的字体)
     GifValidate.ValidateCodeFont = "Arial";
     //验证码字符是否消除锯齿
     GifValidate.FontTextRenderingHint = false;
     //定义验证码中所有的字符(","分离),似乎暂时不支持中文
     GifValidate.AllChar = "1,2,3,4,5,6,7,8,9,0,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P,Q,R,S,T,U,W,X,Y,Z";
     #endregion
 
     //输出图像(Session名称)
     GifValidate.OutPutValidate("GetCode");
   }

메인 메소드 호출 :

public class Validate
  {
    public string AllChar = "1,2,3,4,5,6,7,8,9,0,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P,Q,R,S,T,U,W,X,Y,Z";
    public Color DrawColor = Color.BlueViolet;
    public bool FontTextRenderingHint = false;
    public int ImageHeight = 0x17;
    private byte TrueValidateCodeCount = 4;
    protected string ValidateCode = "";
    public string ValidateCodeFont = "Arial";
    public float ValidateCodeSize = 13f;
 
    private void CreateImageBmp(out Bitmap ImageFrame)
    {
      char[] chArray = this.ValidateCode.ToCharArray(0, this.ValidateCodeCount);
      int width = (int) (((this.TrueValidateCodeCount * this.ValidateCodeSize) * 1.3) + 4.0);
      ImageFrame = new Bitmap(width, this.ImageHeight);
      Graphics graphics = Graphics.FromImage(ImageFrame);
      graphics.Clear(Color.White);
      Font font = new Font(this.ValidateCodeFont, this.ValidateCodeSize, FontStyle.Bold);
      Brush brush = new SolidBrush(this.DrawColor);
      int maxValue = (int) Math.Max((float) ((this.ImageHeight - this.ValidateCodeSize) - 3f), (float) 2f);
      Random random = new Random();
      for (int i = 0; i < this.TrueValidateCodeCount; i++)
      {
        int[] numArray = new int[] { (((int) (i * this.ValidateCodeSize)) + random.Next(1)) + 3, random.Next(maxValue) };
        Point point = new Point(numArray[0], numArray[1]);
        if (this.FontTextRenderingHint)
        {
          graphics.TextRenderingHint = TextRenderingHint.SingleBitPerPixel;
        }
        else
        {
          graphics.TextRenderingHint = TextRenderingHint.AntiAlias;
        }
        graphics.DrawString(chArray[i].ToString(), font, brush, (PointF) point);
      }
      graphics.Dispose();
    }
 
    private void CreateImageGif()
    {
      AnimatedGifEncoder encoder = new AnimatedGifEncoder();
      MemoryStream stream = new MemoryStream();
      encoder.Start();
      encoder.SetDelay(5);
      encoder.SetRepeat(0);
      for (int i = 0; i < 10; i++)
      {
        Bitmap bitmap;
        this.CreateImageBmp(out bitmap);
        this.DisposeImageBmp(ref bitmap);
        bitmap.Save(stream, ImageFormat.Png);
        encoder.AddFrame(Image.FromStream(stream));
        stream = new MemoryStream();
      }
      encoder.OutPut(ref stream);
      HttpContext.Current.Response.ClearContent();
      HttpContext.Current.Response.ContentType = "image/Gif";
      HttpContext.Current.Response.BinaryWrite(stream.ToArray());
      stream.Close();
      stream.Dispose();
    }
 
    private void CreateValidate()
    {
      this.ValidateCode = "";
      string[] strArray = this.AllChar.Split(new char[] { &#39;,&#39; });
      int index = -1;
      Random random = new Random();
      for (int i = 0; i < this.ValidateCodeCount; i++)
      {
        if (index != -1)
        {
          random = new Random((i * index) * ((int) DateTime.Now.Ticks));
        }
        int num3 = random.Next(0x23);
        if (index == num3)
        {
          this.CreateValidate();
        }
        index = num3;
        this.ValidateCode = this.ValidateCode + strArray[index];
      }
      if (this.ValidateCode.Length > this.TrueValidateCodeCount)
      {
        this.ValidateCode = this.ValidateCode.Remove(this.TrueValidateCodeCount);
      }
    }
 
    private void DisposeImageBmp(ref Bitmap ImageFrame)
    {
      Graphics graphics = Graphics.FromImage(ImageFrame);
      Pen pen = new Pen(this.DrawColor, 1f);
      Random random = new Random();
      Point[] pointArray = new Point[2];
      for (int i = 0; i < 15; i++)
      {
        pointArray[0] = new Point(random.Next(ImageFrame.Width), random.Next(ImageFrame.Height));
        pointArray[1] = new Point(random.Next(ImageFrame.Width), random.Next(ImageFrame.Height));
        graphics.DrawLine(pen, pointArray[0], pointArray[1]);
      }
      graphics.Dispose();
    }
 
    public void OutPutValidate(string ValidateCodeSession)
    {
      this.CreateValidate();
      this.CreateImageGif();
      HttpContext.Current.Session[ValidateCodeSession] = this.ValidateCode;
    }
 
    public byte ValidateCodeCount
    {
      get
      {
        return this.TrueValidateCodeCount;
      }
      set
      {
        if (value > 4)
        {
          this.TrueValidateCodeCount = value;
        }
      }
    }
  }

위는 ASP.NET을 구현하는 전체 과정이고, 소스코드도 첨부해 주시길 바랍니다. ASP.NET 확인 코드를 생성하는 방법을 알아보세요.

12306 동적 인증 코드에서 영감을 받은 동적 GIF 인증 코드를 구현하는 ASP.NET에 대한 더 많은 관련 기사를 보려면 PHP 중국어 웹사이트를 주목하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.