>  기사  >  백엔드 개발  >  ASP.NET 인증코드 생성 방법에 대한 자세한 설명

ASP.NET 인증코드 생성 방법에 대한 자세한 설명

高洛峰
高洛峰원래의
2017-01-13 14:57:221308검색

일반적인 인증 코드 생성 방법은 두 가지 주요 단계로 구성됩니다.

첫 번째 단계: 시스템 인증 코드의 숫자 또는 문자를 무작위로 생성합니다. 숫자나 문자를 쿠키나 세션에 씁니다.

2단계: 1단계에서 무작위로 생성된 숫자나 문자를 이용해 그림을 합성합니다.

인증코드의 복잡도는 주로 2단계에서 완료되는 것을 볼 수 있으며, 원하는 복잡도에 따라 설정하시면 됩니다.

살펴보자:

1단계: 숫자 또는 문자를 무작위로 생성하는 방법

/// <summary>
  /// 生成验证码的随机数
  /// </summary>
  /// <returns>返回五位随机数</returns>
  private string GenerateCheckCode()
  {
    int number;
    char code;
    string checkCode = String.Empty;
 
    Random random = new Random();
 
    for (int i = 0; i < 5; i++)//可以任意设定生成验证码的位数
    {
      number = random.Next();
 
      if (number % 2 == 0)
        code = (char)(&#39;0&#39; + (char)(number % 10));
      else
        code = (char)(&#39;A&#39; + (char)(number % 26));
 
      checkCode += code.ToString();
    }
 
    Response.Cookies.Add(new HttpCookie("CheckCode", checkCode));//写入COOKIS
    Session["CheckCode"] = checkCode; //写入Session,可以任意选一下
    return checkCode;
  }

2단계: 사진 생성

/// <summary>
  /// 生成验证码图片
  /// </summary>
  /// <param name="checkCode"></param>
  private void CreateCheckCodeImage(string checkCode)
  {
    if (checkCode == null || checkCode.Trim() == String.Empty)
      return;
 
    Bitmap image = new 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));
      LinearGradientBrush brush = new 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);
 
      MemoryStream ms = new MemoryStream();
      image.Save(ms, System.Drawing.Imaging.ImageFormat.Gif);
      Response.ClearContent();
      Response.ContentType = "image/Gif";
      Response.BinaryWrite(ms.ToArray());
    }
    finally
    {//释放对象资源
      g.Dispose();
      image.Dispose();
    }

* 프로그램 완성

먼저 VS2005의 프로젝트에 checkCode.aspx 파일을 추가하고 checkCode.aspx.cs 코드 파일에 다음 전체 코드를 추가합니다

using System;
using System.Data;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using System.Drawing;
using System.IO;
using System.Drawing.Drawing2D;
 
public partial class checkCode : System.Web.UI.Page
{
  protected void Page_Load(object sender, EventArgs e)
  {
    CreateCheckCodeImage(GenerateCheckCode());//调用下面两个方法;
  }
 
  /// <summary>
  /// 生成验证码的随机数
  /// </summary>
  /// <returns>返回五位随机数</returns>
  private string GenerateCheckCode()
  {
    int number;
    char code;
    string checkCode = String.Empty;
 
    Random random = new Random();
 
    for (int i = 0; i < 5; i++)//可以任意设定生成验证码的位数
    {
      number = random.Next();
 
      if (number % 2 == 0)
        code = (char)(&#39;0&#39; + (char)(number % 10));
      else
        code = (char)(&#39;A&#39; + (char)(number % 26));
 
      checkCode += code.ToString();
    }
 
    Response.Cookies.Add(new HttpCookie("CheckCode", checkCode));//写入COOKIS
    Session["CheckCode"] = checkCode; //写入Session,可以任意选一下
    return checkCode;
  }
 
 
  /// <summary>
  /// 生成验证码图片
  /// </summary>
  /// <param name="checkCode"></param>
  private void CreateCheckCodeImage(string checkCode)
  {
    if (checkCode == null || checkCode.Trim() == String.Empty)
      return;
 
    Bitmap image = new 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));
      LinearGradientBrush brush = new 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);
 
      MemoryStream ms = new MemoryStream();
      image.Save(ms, System.Drawing.Imaging.ImageFormat.Gif);
      Response.ClearContent();
      Response.ContentType = "image/Gif";
      Response.BinaryWrite(ms.ToArray());
    }
    finally
    {//释放对象资源
      g.Dispose();
      image.Dispose();
    }
  }
 
}

인증을 생성하는 페이지에 대해 동일한 작업을 수행합니다. 위의 코드를 호출해 보겠습니다.

인증 코드를 사용해야 하는 곳에 이미지 컨트롤을 추가하세요

a08766dae5ddfc882fb1e215b2d4231e

이렇게 하면 이미지 컨트롤에 인증코드가 표시됩니다!

표시가 완료되었으니 당연히 사용자의 입력이 맞는지 판단해야겠죠!

사용자가 입력한 값을 가져와 쿠키나 세션과 비교하면 괜찮습니다.

쿠키 값 Request.Cookies["CheckCode"].Value를 가져옵니다.

Session Value Session["CheckCode"].ToString() (세션이 비어 있는지 먼저 확인하는 것이 가장 좋습니다)

대소문자를 구분하고 싶지 않은 경우 , 사용자가 입력한 값과 Cookies 또는 Session 값을 대문자 또는 모두 소문자로 변환

사용법에 따라

protected void Button1_Click(object sender, EventArgs e)
  {
    if (Request.Cookies["CheckCode"].Value == TextBox1.Text.Trim().ToString())
    {
      Response.Write("Cookies is right");
    }
    else
    {
      Response.Write("Cookies is wrong");
    }
 
    if (Session["CheckCode"] != null)
    {
      if (Session["CheckCode"].ToString().ToUpper() == TextBox1.Text.Trim().ToString().ToUpper())
        //这样写可以不能区分大小写
      {
        Response.Write("Session is right");
 
      }
      else
      {
        Response.Write("Session is wrong");
      }
    }
  }

위 내용은 이 글의 전체 내용이며, 만드는 방법을 알려드립니다. ASP.NET 인증 코드가 마음에 드셨으면 좋겠습니다.

ASP.NET 인증 코드 생성 방법에 대한 자세한 내용은 PHP 중국어 웹사이트를 참고하세요!

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