驗證碼

<title>驗證碼</title>
<script type="text/javascript">
//点击切换验证码
function f_refreshtype() {
var Image1 = document.getElementById("img");
if (Image1 != null) {
Image1.src = Image1.src + "?";
}
}
</script>
</head>
<body>
<form id="form1" runat="server">
<div>

<span>--------------------驗證碼1--------------------</span>
<div>
<span id="identifyingCode">驗證碼:</span>
<input id="txtCode" type="text" />
<!----javascript:var time = new Date().getTime(); this.src=this.src + ‘?‘ + time;//點擊換驗證碼----->
<img src="IdentifyingCode.aspx"
style="vertical-align:bottom; margin-bottom:1px; cursor: pointer;"
alt="点击刷新" onclick="javascript:var time = new Date().getTime(); this.src=this.src + ‘?‘ + time;"/>

</div>

<div>
<span>--------------------驗證碼2--------------------</span>
<table>
<tr>
<td>
<span >驗證碼:</span><input id="TextBox1" type="text" runat="server" />
</td>
<td>
<img src="png.aspx" id="img" onclick="f_refreshtype()" />
</td>
<td>
<asp:Button ID="Button1" runat="server" Text="确定" />
</td>
</tr>
</table>
</div>
</div>
</form>
</body>

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

namespace _5._15Practice
{
public partial class WebForm1 : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
string randomcode = this.CreateRandomCode(4);
Response.Cookies.Add(new HttpCookie("CheckCode", randomcode));
//ViewState["ValidateCode"] = randomcode; // Session、Cookie、ViewState都可保存,根据实际情况定
this.CreateImage(randomcode);

}
#region 生成一定长度的验证码
/// <summary>
/// 生成随机码
/// </summary>
/// <param name="length">随机码个数</param>
/// <returns></returns>
private string CreateRandomCode(int length)
{
int rand;
char code;
string randomcode = String.Empty;

//生成一定长度的验证码
System.Random random = new Random();
for (int i = 0; i < length; i++)
{
rand = random.Next();

if (rand % 3 == 0)
{
code = (char)(‘A‘ + (char)(rand % 26));
}
else
{
code = (char)(‘0‘ + (char)(rand % 10));
}

randomcode += code.ToString();
}
return randomcode;
}
#endregion

#region 创建随机码图片
/// <summary>
/// 创建随机码图片
/// </summary>
/// <param name="randomcode">随机码</param>
private void CreateImage(string randomcode)
{
int randAngle = 45; //随机转动角度
int mapwidth = (int)(randomcode.Length * 16);
Bitmap map = new Bitmap(mapwidth, 28); //创建图片背景,设置其长宽
Graphics graph = Graphics.FromImage(map);//繪圖圖面
graph.Clear(Color.AliceBlue);//清除繪圖面,并用指定顔色填充
graph.DrawRectangle(new Pen(Color.Black, 0), 0, 0, map.Width - 1, map.Height - 1);//画一个边框

Random rand = new Random();//隨機數生成器

#region 生成背景噪点
// 生成背景噪点
Pen blackPen = new Pen(Color.LightGray, 0);//定義一個畫筆
for (int i = 0; i < 200; i++)//噪點個數
{
int x = rand.Next(0, map.Width);
int y = rand.Next(0, map.Height);
graph.DrawRectangle(blackPen, x, y, 1, 1);//隨機分佈
}
#endregion

#region 验证码旋转,防止机器识别
//验证码旋转,防止机器识别
char[] chars = randomcode.ToCharArray();//拆散字符串成单字符数组

//文字距中
///封裝文本佈局信息--文字距中
StringFormat format = new StringFormat(StringFormatFlags.NoClip);
format.Alignment = StringAlignment.Center;//水平對齊方式
format.LineAlignment = StringAlignment.Center;//垂直對齊方式

/// 定义随机颜色列表
Color[] c = { Color.Black, Color.Red, Color.DarkBlue, Color.Green, Color.Orange, Color.Brown, Color.DarkCyan, Color.Purple };
/// 定义随机字体字体
string[] font = { "Verdana", "Microsoft Sans Serif", "Comic Sans MS", "Arial", "宋体" };

for (int i = 0; i < chars.Length; i++)
{
///顔色下標
int cindex = rand.Next(7);
///字體下標
int findex = rand.Next(5);
///設定文本格式
Font f = new System.Drawing.Font(font[findex], 16, System.Drawing.FontStyle.Bold); // 字体样式(第二参数为字体大小)
Brush b = new System.Drawing.SolidBrush(c[cindex]);

Point dot = new Point(11, 11); // 括号内数值越大,字符间距越大
float angle = rand.Next(0, randAngle); // 转动的度数,如果将0改为-randAngle,那么旋转角度为-45度~45度

graph.TranslateTransform(dot.X, dot.Y);
graph.RotateTransform(angle);
graph.DrawString(chars[i].ToString(), f, b, 2, 6, format); // 第4、5个参数控制左、上间距
graph.RotateTransform(-angle);
graph.TranslateTransform(2, -dot.Y);
}
#endregion

//生成图片
System.IO.MemoryStream ms = new System.IO.MemoryStream();
map.Save(ms, System.Drawing.Imaging.ImageFormat.Gif);
Response.ClearContent();
Response.ContentType = "image/gif";
Response.BinaryWrite(ms.ToArray());
graph.Dispose();
map.Dispose();
}
#endregion

}
}

參考博客大牛http://www.cnblogs.com/nyzhai/p/CheckCode.html  等

时间: 2024-10-12 18:54:37

驗證碼的相关文章

用戶登陸。防SQL注入,驗證碼不區分大小寫。。

if (string.Compare(TBCheckCode.Text, Session["CheckCodeI"].ToString(), true) == 0)        {            string password = FormsAuthentication.HashPasswordForStoringInConfigFile(TBpassword.Text, "md5");//MD5加密            string mycon = C

使用 Regular Expression 驗證密碼複雜度

以前我都沒想過可以用 Regular Expressions 驗證複雜格式的密碼,原來可以用 Regular Expression 中的群組建構式達成這個目的,例如說密碼的條件是這樣: 至少有一個數字 至少有一個小寫英文字母 至少有一個大寫英文字母 字串長度在 6 ~ 30 個字母之間 那麼你的 Regular Expression 可以長這樣: ^(?=.*\d)(?=.*[a-z])(?=.*[A-Z]).{6,30}$ 在這段 Regular Expression 的語法中值得注意的就是 

.net使用微軟自帶的用戶驗證和登錄授權

使用微軟的用戶驗證,權限管理的方法 一.使用配置好的數據庫, 1.首先建立想定的數據庫(只填寫名字不加載任何表,如:Login數據庫) 2.使用vs兼容工具命令提示.如圖: 3.導入數據庫所需要的table a.使用剛才打開的工具命令提示,寫入代碼aspnet_regsql如圖 b.打開如下窗口后進行配置 注意上面箭頭的位置要與剛才,或者事先準備好的數據庫對應起來. 之後就是點下一步和完成就OK了. 配置完后的數據庫裡面的表 到目前位置數據庫的配置已經完成,下面就是使用 二.編寫配置文件 <co

實際案例: 接口接入驗證 (公眾號設定)

一.登入官方的微信公眾號平台 二.進入設定頁面 三.進入服務器配置 四.填寫握修改配置信息 補充說明: 1.URL:就是做轉接的網址,實際執行驗證的程式碼寫在這裡. 2.Token:本質就是一個字串,內容可以隨便輸入,長度在 3 ~ 32 個字元之間,只要後續呼叫時所輸入的 token 和這裡設定的一致即可.講究一點的,可以試試用 Visual Studio 的 GUID 產生器,或者用 SQL Server 的 NewID() 函式產生 32 個字元的字串. 3.EncodingAESKey:

實際案例: 接口接入驗證 (程式碼)

同樣的 本案例也是採用大名鼎鼎的 Senparc 微信開發套件 廢話不多說,具體程式碼如下 using ShouJia.BO; using ShouJia.Common; using ShouJia.Debugger; using ShouJia.Facades; using ShouJia.Framework; using Senparc.Weixin.MP; using System; using System.Data; using System.Data.Common; using Sy

Dependency Injection 筆記 (1)

<.NET 相依性注入>連載 (1) 本文從一個基本的問題開始,點出軟體需求變動的常態,以說明為什麼我們需要學習「相依性注入」(dependency injection:簡稱 DI)來改善設計的品質.接著以一個簡單的入門範例來比較沒有使用 DI 和改寫成 DI 版本之後的差異,並討論使用 DI 的時機.目的是讓讀者先對相關的基礎概念有個概括的理解,包括可維護性(maintainability).寬鬆耦合(loose coupling).控制反轉(inversion of control).動態

Dependency Injection 筆記 (2)

續上集,接著要說明如何運用 DI 來讓剛才的範例程式具備執行時期切換實作類別的能力. 入門範例—DI 版本 為了讓 AuthenticationService 類別能夠在執行時期才決定要使用 EmailService 還是 ShortMessageService 來發送驗證碼,我們必須對這些類別動點小手術,把它們之間原本緊密耦合的關係鬆開——或者說「解耦合」.有一個很有效的工具可以用來解耦合:介面(interface). 說得更明白些,原本 AuthenticationService 是相依於特

BT觀念分享和常見問題彙整

一. TCP/IP基本觀念 1. IP : 每台在TCP/IP網路上的電腦必須具備的一個代表號或一個地址.IP又分為private IP(192.168.x.x /10.x.x.x /172.16.x.x~172.31.x.x)和public IP(除了少數特殊IP,只要不是private IP就是public IP). 2. port : port可視為TCP/IP網路中電腦提供的某種服務的門牌號碼,號碼(port的數值)是多少不重要,號碼代表的服務才重要.例如: port80代表web的服務

如何使用 LDAP 來認證 VPN - 居易科技 DrayTek

如何使用RADIUS/LDAP 來認證VPN遠端撥入使用者? Vigor 系列支援 VPN 遠端撥入使用者的功能,讓電腦可以從遠端用 VPN 連線到 Vigor 設備.而 VPN 的認證方式除了本機認證之外,某些機型也支援 RADIUS server 或是 LDAP/AD server 的認證,以下我們以 Vigor2925 為例,介紹如何設定使用 RADIUS/LDAP/AD 來認證 VPN 遠端撥入帳號. RADIUS server 設定: 請到其他應用> RADIUS,輸入RADIUS s