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)資料,希望對大家的學(xué)習(xí)有所幫助。
相關(guān)文章
Asp.net core中RedisMQ的簡單應(yīng)用實現(xiàn)
這篇文章主要介紹了Asp.net core中RedisMQ的簡單應(yīng)用實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12開源跨平臺運行服務(wù)插件TaskCore.MainForm
這篇文章主要為大家詳細介紹了開源跨平臺運行服務(wù)插件TaskCore.MainForm的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-06-06.NET Core中使用Redis與Memcached的序列化問題詳析
這篇文章主要介紹了.NET Core中使用Redis與Memcached的序列化問題的相關(guān)內(nèi)容,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2018-03-03asp.net+Ajax校驗用戶是否存在的實現(xiàn)代碼
主要技術(shù)點 jquery ajax以及blur事件,當用戶名輸入框失去焦點的時候就會觸發(fā)blur事件,然后進行ajax請求,獲得結(jié)果(true或者false),如果請求結(jié)果為true,就把用戶名輸入框圖片替換成ok,并且輸出文字:恭喜您2012-05-05ASP.NET AJAX 4.0的模版編程(Template Programming)介紹
不過當我評估ASP.NET AJAX 4.0的時候,我確實被它的特征給震住了。新的特征完全專注于瀏覽器技術(shù),比如XHTML和javascript。 我非常欽佩ASP.NET AJAX小組。2009-07-07