asp.net生成字母和數(shù)字混合圖形驗證碼
驗證碼技術(shù)是網(wǎng)站開發(fā)過程中比較重要的技術(shù),可以防止非法人員利用注冊機或者登陸工具來攻擊我們的網(wǎng)站。下面是效果圖:

具體實現(xiàn)方法如下:
1、主要思路是:引用Using System.Drawing命名空間,利用Graphics的FromImage方法創(chuàng)建一個畫布,同時設(shè)置畫布的寬和高,然后通過Graphics類 的DrawString方法隨機生成的字符串繪制到畫布中,繪制驗證碼的同時,在畫布中利用SetPixel方法繪制一些色點,從而防止非法人員利用機器 人來進行登陸。當我們繪制驗證碼完畢后,在需要驗證碼的頁面中利用Image空間將其顯示出來,Image控件顯示驗證碼的HTML源碼設(shè)置如下:
<asp:Image ID="Image1" runat="server"ImageUrl="~/ValidateNum.aspx" /> <asp:LinkButton ID="LinkButton1" runat="server" style="font-size: small; ">看不清,換一張</asp:LinkButton>
2、這里所用到的ValidateNum.aspx頁面代碼如下:
using System;
using System.Collections;
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 ValidateNum : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
string validateNum = CreateRandomNum(4);//成生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,L,M,N,O,P,Q,R,S,T,U,W,X,Y,Z";
string[] allCharArray = allChar.Split(',');//拆分成數(shù)組
string randomNum = "";
int temp = -1;//記錄上次隨機數(shù)的數(shù)值,盡量避免產(chǎn)生幾個相同的隨機數(shù)
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 + 10, 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(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();
}
}
}
以上就是關(guān)于asp.net生成圖形驗證碼的相關(guān)資料,希望對大家的學習有所幫助。
相關(guān)文章
Javascript 直接調(diào)用服務器C#代碼 ASP.NET Ajax實例
近來總有一些朋友會問到一些入門的問題,把這些問題整理一下,寫出來。在以前的文章里,曾經(jīng)利用純JS編寫過Ajax引擎,在真正開發(fā)的時候,大家都不喜歡以這種低效率的方式開發(fā),利用MS Ajax的集成的引擎,可以簡單不少工作。2010-03-03
在.NET使用JSON作為數(shù)據(jù)交換格式實例演示
JSON(JavaScript Object Notation)是一種輕量級輕量級的數(shù)據(jù)交換格式,并且它獨立于編程語言,接下來為大家介紹下使用JSON作為數(shù)據(jù)交換格式在.net中的應用2013-03-03
asp.net MVC利用自定義ModelBinder過濾關(guān)鍵字的方法(附demo源碼下載)
這篇文章主要介紹了MVC利用自定義ModelBinder過濾關(guān)鍵字的方法,結(jié)合實例形式詳細分析了自定義ModelBinder過濾關(guān)鍵字的原理與具體實現(xiàn)技巧,需要的朋友可以參考下2016-03-03
asp.net 使用Response.Filter 過濾非法詞匯
一般信息發(fā)布網(wǎng)站,論壇等均具有實現(xiàn)非法詞匯過濾功能,即當用戶錄入非法詞匯時,進行替換,使其無法顯示到頁面上,針對此種功能,通常采用的時,在讀取時,在讀到非法詞匯后,進行替換。2010-03-03
在ASP.Net?Core應用程序中使用Bootstrap4
這篇文章介紹了在ASP.Net?Core應用程序中使用Bootstrap4的方法,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2022-01-01

