ホームページ > バックエンド開発 > C#.Net チュートリアル > ASP.NET がグラフィック検証コードを生成する方法の詳細な説明

ASP.NET がグラフィック検証コードを生成する方法の詳細な説明

高洛峰
リリース: 2017-01-09 09:28:58
オリジナル
1293 人が閲覧しました

この記事の例では、ASP.NET がグラフィカルな検証コードを生成する方法について説明します。参考のために皆さんと共有してください。詳細は次のとおりです:

通常、グラフィカルな検証コードを生成するには 3 つの主な手順があります:

(1) 長さ N のランダムな文字列をランダムに生成します。N の値は設定できます。開発者による。文字列には数字、文字などを含めることができます。
(2) ランダムに生成した文字列を画像に作成して表示します。
(3) 認証コードを保存します。

default.aspx として新しいページを作成し、TextBox コントロールと Image コントロールを配置します。TextBox コントロールは生成された文字列を入力するために使用され、Image コントロールは生成されたグラフィック検証を表示するために使用されます。 code imageUrl=" /default.aspx";

default.aspx ページのソース コードは次のとおりです:

<form id="form1" runat="server">
  <div>
    <asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>
    <asp:Image ID="Image1" imageUrl=“/default.aspx” runat="server" />
  </div>
</form>
ログイン後にコピー

グラフィック検証コードのコードは次のとおりです:

using System;
using System.Configuration;
using System.Data;
using System.Linq;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.HtmlControls;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Xml.Linq;
using System.Drawing;
public partial class _Default : System.Web.UI.Page
{
  protected void Page_Load(object sender, EventArgs e)
  {
    if (!IsPostBack)
    {
      string validateNum = CreateRandomNum(4);
      CreateImage(validateNum);
      Session["ValidateNum"] = validateNum;
    }
  }
  //生产随机数
  private string CreateRandomNum(int NumCount)
  {
    string allChar = "0,1,2,3,4,5,6,7,8,9,A,B,C,D,E,F,G,H,I,J,K,O,P,Q,R,S,T,U,W,X,Y,Z,a,b,c,d,e,f,g,h,i,j,k,m,n,o,p,q,s,t,u,w,x,y,z";
    string[] allCharArray = allChar.Split(&#39;,&#39;);//拆分成数组
    string randomNum = "";
    int temp = -1;               //记录上次随机数的数值,尽量避免产生几个相同的随机数
    Random rand = new Random();
    for (int i = 0; i < NumCount; i++)
    {
      if (temp != -1)
      {
        rand = new Random(i*temp*((int)DateTime.Now.Ticks));
      }
      int t = rand.Next(35);
      if (temp == t)
      {
        return CreateRandomNum(NumCount);
      }
      temp = t;
      randomNum += allCharArray[t];
    }
    return randomNum;
  }
  //生产图片
  private void CreateImage(string validateNum)
  {
    if (validateNum == null || validateNum.Trim() == string.Empty)
      return;
    //生成BitMap图像
    System.Drawing.Bitmap image = new System.Drawing.Bitmap(validateNum.Length*12+12,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,x2,y1,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(validateNum,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);
      Response.ClearContent();
      Response.ContentType="image/Gif";
      Response.BinaryWrite(ms.ToArray());
    }
    finally
    {
      g.Dispose();
      image.Dispose();
    }
  }
}
ログイン後にコピー

この記事は、asp.net プログラミングに携わるすべての人にとって役立ちます。

ASP.NET がグラフィック検証コードを生成する方法の詳細な説明と関連記事については、PHP 中国語 Web サイトに注目してください。


関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート