搜尋
首頁後端開發C#.Net教程ASP.NET中的無刷新驗證碼的開發

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Login.aspx.cs" Inherits="Login" %> 

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
<html xmlns="http://www.w3.org/1999/xhtml" > 
<head id="Head1" runat="server"> 
<title>无标题页</title> 
<script type="text/javascript"> 
function DoFresh() { 
document.getElementById("Image1").src = "VerifyCode.aspx"; 
} 
</script> 
</head> 
<body> 
<form id="form1" runat="server"> 
<div> 
<table> 
<tr> 
<td> 
验证码:<asp:TextBox ID="txtValidateCode" runat="server"></asp:TextBox> 
</td> 
<td> 
<asp:Image ID="Image1" runat="server" /> 
<a href="javascript:DoFresh();">看不清?</a> 
</td> 
</tr> 
<tr> 
<td align="center" colspan="2"> 
<br /> 
<asp:Literal ID="litErrorMsg" runat="server"></asp:Literal> 
<asp:Button ID="btnSubmit" runat="server" Text="确定" onclick="btnSubmit_Click" /> 
</td> 
</tr> 
</table> 
</div> 
</form> 
</body> 
</html> 


using System; 
using System.Collections.Generic; 
using System.Linq; 
using System.Web; 
using System.Web.UI; 
using System.Web.UI.WebControls; 

public partial class Login : System.Web.UI.Page 
{ 
protected void Page_Load(object sender, EventArgs e) 
{ 
if (!Page.IsPostBack) 
{ 
Image1.ImageUrl = "VerifyCode.aspx"; 
} 
} 
protected void btnSubmit_Click(object sender, EventArgs e) 
{ 
if (Session["ValidateCode"] != null) 
{ 
string outputValidateCode = Session["ValidateCode"] as string; 
string inputValidateCode = txtValidateCode.Text.Trim(); 
if (string.Compare(outputValidateCode, inputValidateCode, true) != 0) 
{ 
//Response.Write("<script>javascript:alert(&#39;输入的验证码错误!&#39;);</script>"); 
litErrorMsg.Text = "输入的验证码错误!"; 
} 
else 
{ 
//Response.Write("<script>javascript:alert(&#39;输入的验证码正确!&#39;);</script>"); 
litErrorMsg.Text = "输入的验证码正确!"; 
} 
} 
} 
#region 调用下面的方法实现客户端保存Cookie验证模式 
private void ValidateMethod() 
{ 
if (Request.Cookies["CheckCode"] == null) 
{ 
litErrorMsg.Text = "您的浏览器设置已被禁用 Cookies,您必须设置浏览器允许使用 Cookies 选项后才能使用本系统。"; 
litErrorMsg.Visible = true; 
return; 
} 
if (String.Compare(Request.Cookies["CheckCode"].Value, TextBox1.Text.ToString().Trim(), true) != 0) 
{ 
litErrorMsg.Text = "<font color=red>对不起,验证码错误!</font>"; 
litErrorMsg.Visible = true; 
return; 
} 
else 
{ 
litErrorMsg.Text = "<font color=green>恭喜,验证码输入正确!</font>"; 
litErrorMsg.Visible = true; 
} 
} 
#endregion 
}

//VerifyCode.aspx為預設產生的程式碼 

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.WebParts; 
using System.Web.UI.HtmlControls; 
using System.Drawing; 
using System.Drawing.Imaging; 
using System.Drawing.Drawing2D; 
using System.IO; 
public partial class VerifyCode : System.Web.UI.Page 
{ 
protected void Page_Load(object sender, EventArgs e) 
{ 
//GenerateValidateCode(); 
GenerateVerifyImage(4);//GenerateVerifyImage(int length) 
} 

#region 【无刷新仿google波形扭曲彩色】验证码样式0___GenerateValidateCode() 
private void GenerateValidateCode() 
{ 
this.Length = this.length; 
this.FontSize = this.fontSize; 
this.Chaos = this.chaos; 
this.BackgroundColor = this.backgroundColor; 
this.ChaosColor = this.chaosColor; 
this.CodeSerial = this.codeSerial; 
this.Colors = this.colors; 
this.Fonts = this.fonts; 
this.Padding = this.padding; 
string VNum = this.CreateVerifyCode(); //取随机码 
Session["ValidateCode"] = VNum.ToUpper();//取得验证码,以便后来验证 
this.CreateImageOnPage(VNum, this.Context); // 输出图片 
//Cookie验证模式, 使用Cookies取验证码的值 
//Response.Cookies.Add(new HttpCookie("CheckCode", code.ToUpper())); 
} 
#endregion 
#region 验证码长度(默认4个验证码的长度) 
int length = 4; 
public int Length 
{ 
get { return length; } 
set { length = value; } 
} 
#endregion 
#region 验证码字体大小(为了显示扭曲效果,默认40像素,可以自行修改) 
int fontSize = 22; 
public int FontSize 
{ 
get { return fontSize; } 
set { fontSize = value; } 
} 
#endregion 
#region 边框补(默认1像素) 
int padding = 2; 
public int Padding 
{ 
get { return padding; } 
set { padding = value; } 
} 
#endregion 
#region 是否输出燥点(默认不输出) 
bool chaos = true; 
public bool Chaos 
{ 
get { return chaos; } 
set { chaos = value; } 
} 
#endregion 
#region 输出燥点的颜色(默认灰色) 
Color chaosColor = Color.LightGray; 
public Color ChaosColor 
{ 
get { return chaosColor; } 
set { chaosColor = value; } 
} 
#endregion 
#region 自定义背景色(默认白色) 
Color backgroundColor = Color.White; 
public Color BackgroundColor 
{ 
get { return backgroundColor; } 
set { backgroundColor = value; } 
} 
#endregion 
#region 自定义随机颜色数组 
Color[] colors = { Color.Black, Color.Red, Color.DarkBlue, Color.Green, Color.Orange, Color.Brown, Color.DarkCyan, Color.Purple }; 
public Color[] Colors 
{ 
get { return colors; } 
set { colors = value; } 
} 
#endregion 
#region 自定义字体数组 
string[] fonts = { "Arial", "Georgia" }; 
public string[] Fonts 
{ 
get { return fonts; } 
set { fonts = value; } 
} 
#endregion 
#region 自定义随机码字符串序列(使用逗号分隔) 
string codeSerial = "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,v,w,x,y,z,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P,Q,R,S,T,U,V,W,X,Y,Z"; 
public string CodeSerial 
{ 
get { return codeSerial; } 
set { codeSerial = value; } 
} 
#endregion 
#region 产生波形滤镜效果 
private const double PI = 3.1415926535897932384626433832795; 
private const double PI2 = 6.283185307179586476925286766559; 
/// <summary> 
/// 正弦曲线Wave扭曲图片 
/// </summary> 
/// <param name="srcBmp">图片路径</param> 
/// <param name="bXDir">如果扭曲则选择为True</param> 
/// <param name="nMultValue">波形的幅度倍数,越大扭曲的程度越高,一般为3</param> 
/// <param name="dPhase">波形的起始相位,取值区间[0-2*PI)</param> 
/// <returns></returns> 
public Bitmap TwistImage(Bitmap srcBmp, bool bXDir, double dMultValue, double dPhase) 
{ 
Bitmap destBmp = new Bitmap(srcBmp.Width, srcBmp.Height); 
// 将位图背景填充为白色 
System.Drawing.Graphics graph = Graphics.FromImage(destBmp); 
graph.FillRectangle(new SolidBrush(Color.White), 0, 0, destBmp.Width, destBmp.Height); 
graph.Dispose(); 
double dBaseAxisLen = bXDir ? (double)destBmp.Height : (double)destBmp.Width; 
for (int i = 0; i < destBmp.Width; i++) 
{ 
for (int j = 0; j < destBmp.Height; j++) 
{ 
double dx = 0; 
dx = bXDir ? (PI2 * (double)j) / dBaseAxisLen : (PI2 * (double)i) / dBaseAxisLen; 
dx += dPhase; 
double dy = Math.Sin(dx); 
// 取得当前点的颜色 
int nOldX = 0, nOldY = 0; 
nOldX = bXDir ? i + (int)(dy * dMultValue) : i; 
nOldY = bXDir ? j : j + (int)(dy * dMultValue); 
System.Drawing.Color color = srcBmp.GetPixel(i, j); 
if (nOldX >= 0 && nOldX < destBmp.Width 
&& nOldY >= 0 && nOldY < destBmp.Height) 
{ 
destBmp.SetPixel(nOldX, nOldY, color); 
} 
} 
} 
return destBmp; 
} 
#endregion 
#region 生成校验码图片 
public Bitmap CreateImageCode(string code) 
{ 
int fSize = FontSize; 
int fWidth = fSize + Padding; 
int imageWidth = (int)(code.Length * fWidth) + 4 + Padding * 2; 
int imageHeight = fSize * 2 + Padding; 
System.Drawing.Bitmap image = new System.Drawing.Bitmap(imageWidth, imageHeight); 
Graphics g = Graphics.FromImage(image); 
g.Clear(BackgroundColor); 
Random rand = new Random(); 
//给背景添加随机生成的燥点 
if (this.Chaos) 
{ 
Pen pen = new Pen(ChaosColor, 0); 
int c = Length * 10; 
for (int i = 0; i < c; i++) 
{ 
int x = rand.Next(image.Width); 
int y = rand.Next(image.Height); 
g.DrawRectangle(pen, x, y, 1, 1); 
} 
} 
int left = 0, top = 0, top1 = 1, top2 = 1; 
int n1 = (imageHeight - FontSize - Padding * 2); 
int n2 = n1 / 4; 
top1 = n2; 
top2 = n2 * 2; 
Font f; 
Brush b; 
int cindex, findex; 
//随机字体和颜色的验证码字符 
for (int i = 0; i < code.Length; i++) 
{ 
cindex = rand.Next(Colors.Length - 1); 
findex = rand.Next(Fonts.Length - 1); 
f = new System.Drawing.Font(Fonts[findex], fSize, System.Drawing.FontStyle.Bold); 
b = new System.Drawing.SolidBrush(Colors[cindex]); 
if (i % 2 == 1) 
{ 
top = top2; 
} 
else 
{ 
top = top1; 
} 
left = i * fWidth; 
g.DrawString(code.Substring(i, 1), f, b, left, top); 
} 
//画一个边框 边框颜色为Color.Gainsboro 
g.DrawRectangle(new Pen(Color.Gainsboro, 0), 0, 0, image.Width - 1, image.Height - 1); 
g.Dispose(); 
//产生波形(Add By 51aspx.com) 
image = TwistImage(image, true, 4, 4); 
return image; 
} 
#endregion 
#region 将创建好的图片输出到页面 
public void CreateImageOnPage(string code, HttpContext context) 
{ 
Response.BufferOutput = true; //特别注意 
Response.Cache.SetExpires(DateTime.Now.AddMilliseconds(-1));//特别注意 
Response.Cache.SetCacheability(HttpCacheability.NoCache);//特别注意 
Response.AppendHeader("Pragma", "No-Cache"); //特别注意 
MemoryStream ms = new MemoryStream(); 
Bitmap image = this.CreateImageCode(code); 
image.Save(ms, ImageFormat.Jpeg); 
Response.ClearContent(); 
Response.ContentType = "image/JPEG"; 
Response.BinaryWrite(ms.ToArray()); 
Response.End(); 
ms.Close(); 
ms = null; 
image.Dispose(); 
image = null; 
} 
#endregion 
#region 生成随机字符码 
public string CreateVerifyCode(int codeLen) 
{ 
if (codeLen == 0) 
{ 
codeLen = Length; 
} 
string[] arr = CodeSerial.Split(&#39;,&#39;); 
string code = ""; 
int randValue = -1; 
Random rand = new Random(unchecked((int)DateTime.Now.Ticks)); 
for (int i = 0; i < codeLen; i++) 
{ 
randValue = rand.Next(0, arr.Length - 1); 
code += arr[randValue]; 
} 
return code; 
} 
public string CreateVerifyCode() 
{ 
return CreateVerifyCode(0); 
} 
#endregion 
#region 另一种验证码样式 GenerateVerifyImage(int length) 
/// <summary> 
/// 将创建好的图片输出到页面 
/// </summary> 
public void GenerateVerifyImage(int nLen) 
{ 
string validateCode = "";//生成的验证码 
int nBmpWidth = GetImagewidth(nLen); 
int nBmpHeight = GetImageHeight(); 
System.Drawing.Bitmap bmp = new System.Drawing.Bitmap(nBmpWidth, nBmpHeight); 
//对图像进行弯曲 
TwistImage(bmp, true, 12, 2); 

// 1. 生成随机背景颜色 
int nRed, nGreen, nBlue; // 背景的三元色 
System.Random rd = new Random((int)System.DateTime.Now.Ticks); 
nRed = rd.Next(255) % 128 + 128; 
nGreen = rd.Next(255) % 128 + 128; 
nBlue = rd.Next(255) % 128 + 128; 
// 2. 填充位图背景 
System.Drawing.Graphics graph = System.Drawing.Graphics.FromImage(bmp); 
graph.FillRectangle(new SolidBrush(System.Drawing.Color.FromArgb(nRed, nGreen, nBlue)) 
, 0 
, 0 
, nBmpWidth 
, nBmpHeight); 

// 3. 绘制干扰线条,采用比背景略深一些的颜色 
int nLines = 3; 
System.Drawing.Pen pen = new System.Drawing.Pen(System.Drawing.Color.FromArgb(nRed - 17, nGreen - 17, nBlue - 17), 2); 
for (int a = 0; a < nLines; a++) 
{ 
int x1 = rd.Next() % nBmpWidth; 
int y1 = rd.Next() % nBmpHeight; 
int x2 = rd.Next() % nBmpWidth; 
int y2 = rd.Next() % nBmpHeight; 
graph.DrawLine(pen, x1, y1, x2, y2); 
} 
// 采用的字符集,可以随即拓展,并可以控制字符出现的几率 
string strCode = "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"; 
// 4. 循环取得字符,并绘制 
for (int i = 0; i < nLen; i++) 
{ 
int x = (i * 13 + rd.Next(3)); 
int y = rd.Next(4) + 1; 
// 确定字体 
System.Drawing.Font font = new System.Drawing.Font("Courier New",//文字字体类型 
12 + rd.Next() % 4,//文字字体大小 
System.Drawing.FontStyle.Bold);//文字字体样式 
char c = strCode[rd.Next(strCode.Length)]; // 随机获取字符 
validateCode += c.ToString(); 
// 绘制字符 
graph.DrawString(c.ToString(), 
font, 
new SolidBrush(System.Drawing.Color.FromArgb(nRed - 60 + y * 3, nGreen - 60 + y * 3, nBlue - 40 + y * 3)), 
x, 
y); 
} 
Session["ValidateCode"] = validateCode; 
//对图像进行弯曲 
TwistImage(bmp, true, 4, 4); 
Response.BufferOutput = true; //特别注意 
Response.Cache.SetExpires(DateTime.Now.AddMilliseconds(-1));//特别注意 
Response.Cache.SetCacheability(HttpCacheability.NoCache);//特别注意 
Response.AppendHeader("Pragma", "No-Cache"); //特别注意 
// 5. 输出字节流 
MemoryStream bstream = new MemoryStream(); 
bmp.Save(bstream, ImageFormat.Jpeg); 
Response.ClearContent(); 
Response.ContentType = "image/JPEG"; 
Response.BinaryWrite(bstream.ToArray()); 
Response.End(); 
bstream.Close(); 
bstream = null; 
bmp.Dispose(); 
bmp = null; 
graph.Dispose(); 
} 
///<summary> 
///得到验证码图片的宽度 
///</summary> 
///<paramname="validateNumLength">验证码的长度</param> 
///<returns></returns> 
public static int GetImagewidth(int validateNumLength) 
{ 
return (int)(13 * validateNumLength + 5); 
} 
///<summary> 
///得到验证码的高度 
///</summary> 
///<returns></returns> 
public static int GetImageHeight() 
{ 
return 25; 
} 
#endregion 
}

更多ASP.NET中的無刷新驗證碼的開發相關文章請關注PHP中文網!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
char數組在C語言中如何使用char數組在C語言中如何使用Apr 03, 2025 pm 03:24 PM

char 數組在 C 語言中存儲字符序列,聲明為 char array_name[size]。訪問元素通過下標運算符,元素以空終止符 '\0' 結尾,用於表示字符串終點。 C 語言提供多種字符串操作函數,如 strlen()、strcpy()、strcat() 和 strcmp()。

C語言各種符號的使用方法C語言各種符號的使用方法Apr 03, 2025 pm 04:48 PM

C 語言中符號的使用方法涵蓋算術、賦值、條件、邏輯、位運算符等。算術運算符用於基本數學運算,賦值運算符用於賦值和加減乘除賦值,條件運算符用於根據條件執行不同操作,邏輯運算符用於邏輯操作,位運算符用於位級操作,特殊常量用於表示空指針、文件結束標記和非數字值。

char在C語言字符串中的作用是什麼char在C語言字符串中的作用是什麼Apr 03, 2025 pm 03:15 PM

在 C 語言中,char 類型在字符串中用於:1. 存儲單個字符;2. 使用數組表示字符串並以 null 終止符結束;3. 通過字符串操作函數進行操作;4. 從鍵盤讀取或輸出字符串。

。Mar 31, 2025 pm 04:07 PM

.NET異步編程、LINQ和EFCore的核心概念分別是:1.異步編程通過async和await提高應用響應性;2.LINQ通過統一語法簡化數據查詢;3.EFCore通過ORM簡化數據庫操作。

避免 C語言 switch 語句中 default 引起的錯誤避免 C語言 switch 語句中 default 引起的錯誤Apr 03, 2025 pm 03:45 PM

避免 C 語言 switch 語句中 default 引發的錯誤的策略:使用枚舉代替常量,限制 case 語句的值為枚舉的有效成員。在最後一個 case 語句中使用 fallthrough,讓程序繼續執行以下代碼。對於沒有 fallthrough 的 switch 語句,始終添加一個 default 語句進行錯誤處理或提供默認行為。

char在C語言中如何處理特殊字符char在C語言中如何處理特殊字符Apr 03, 2025 pm 03:18 PM

C語言中通過轉義序列處理特殊字符,如:\n表示換行符。 \t表示製表符。使用轉義序列或字符常量表示特殊字符,如char c = '\n'。注意,反斜杠需要轉義兩次。不同平台和編譯器可能有不同的轉義序列,請查閱文檔。

C語言 sum 的作用是什麼?C語言 sum 的作用是什麼?Apr 03, 2025 pm 02:21 PM

C語言中沒有內置求和函數,需自行編寫。可通過遍歷數組並累加元素實現求和:循環版本:使用for循環和數組長度計算求和。指針版本:使用指針指向數組元素,通過自增指針遍歷高效求和。動態分配數組版本:動態分配數組並自行管理內存,確保釋放已分配內存以防止內存洩漏。

char在C語言中如何進行類型轉換char在C語言中如何進行類型轉換Apr 03, 2025 pm 03:21 PM

在 C 語言中,char 類型轉換可以通過:強制類型轉換:使用強制類型轉換符將一種類型的數據直接轉換為另一種類型。自動類型轉換:當一種類型的數據可以容納另一種類型的值時,編譯器自動進行轉換。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱工具

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器