System을 사용; System.Data를 사용; System.Configuration을 사용; System.Collections를 사용; System.Web을 사용; System.Web.Security를 사용; System.Web.UI를 사용; System.Web.UI.WebControls를 사용; System.Web.UI.WebControls.WebParts 사용; System.Web.UI.HtmlControls를 사용; System.Drawing.Design 를 사용한다; System.Drawing을 사용; 공개 부분 클래스 이미지코드 : System.Web.UI.Page
{ protected void Page_Load(object sender, EventArgs e)
{ 이거. CreateCheckCodeImage(RndNum());
}
private string RndNum()
{ 정수; 캐릭터 코드; string checkCode = String.Empty;
시스템. 랜덤 랜덤 = 새로운 랜덤();
(정수: i = 0; 저는 4< 있습니다; i++)
{ 숫자 = 무작위. Next(); 만약 (수 % 2 == 0) 코드 = (char)('0' + (char)(숫자 % 10)); 그렇지 않으면 코드 = (char)('A' + (char)(숫자 % 26)); 체크코드 += 코드. ToString();
} Response.Cookies.Add(새로운 HttpCookie("yzmcode", checkCode)); 체크코드를 반환;
} private void CreateCheckCodeImage(string checkCode)
{ if (checkCode == null || checkCode.Trim() == String.Empty) 복귀; System.Drawing.Bitmap 이미지 = 새 System.Drawing.Bitmap((int)Math.Ceiling((checkCode.Length * 12.5)), 22); 그래픽 g = 그래픽.FromImage(이미지); 시도해
{
//生成随机生成器 랜덤 랜덤 = 새로운 랜덤();
//清空图片背景色 g. 클리어(색상.흰색);
//画图片的背景噪音线 (정수: i = 0; 저는 25< 있습니다; i++)
{ 정수 x1 = 무작위. 다음(이미지. 폭); int x2 = 무작위. 다음(이미지. 폭); int y1 = 무작위. 다음(이미지. 키); int Y2 = 무작위. 다음(이미지. 키); g.DrawLine(새 펜(컬러.Silver), x1, y1, x2, y2);
}
Font font = new System.Drawing.Font("Arial", 12, (System.Drawing.FontStyle.Bold | System.Drawing.FontStyle.Italic)); System.Drawing.Drawing.Drawing2D.LinearGradientBrush 브러시 = 새 System.Drawing.Drawing2D.LinearGradientBrush(새 Rectangle(0, 0, image. 너비, 이미지. 키), 색상.파랑, 색.다크레드, 1.2f, 진짜); g.DrawString(체크코드, 글꼴, 브러시, 2),
//画图片的前景噪音点 (정수: i = 0; 저는 100< 있습니다; i++)
{ 정정성 x = 무작위. 다음(이미지. 폭); int y = 무작위. 다음(이미지. 키); 이미지. SetPixel(x, y, Color.FromArgb(random. Next()));
}
//画图片的边框线 g.DrawRectangle(새 펜(Color.Silver), 0, 0, 이미지. 너비 - 1, 이미지. 높이 - 1); System.IO.MemoryStream ms = 새로운 System.IO.MemoryStream(); 이미지. Save(ms, System.Drawing.Imaging.ImageFormat.Gif); Response.ClearContent(); Response.ContentType = "image/Gif"; Response.BinaryWrite(ms. ToArray());
} 마침내
{ g. Dispose(); 이미지. 처분();
}
}
}
//验证码使用页login.aspx中的代码 <asp:ImageButton ID="yzm" runat="server" ImageUrl="imagecode.aspx" /> <asp:LinkButton ID="ChangeCode" runat="server" text="잘 보이지 않나요? 인증 코드를 변경하세요" /> <asp:Button ID="Button1" runat="server" Text="Button" /></div>
//ogin.aspx.cs中的代码 추가 코드를 작성할 필요 없이, "잘 안 보여요?"를 클릭하세요. 나중에 인증 코드를 새로 고침하기 위해 "인증 코드를 변경하세요" protected void ChangeCode_Click(object sender, EventArgs e)
{
}
//提交按钮代码这里是通过cookies来验证的 protected void Button1_Click(object sender, EventArgs e)
{ if (String.Compare(Request.Cookies["yzmcode"]. 값, a.text, 참) != 0)
{ Response.Write("<scrip去掉t>alert('캡차 오류!')"</scrip去掉t>);
} 그렇지 않으면 { Response.Write("<scrip去掉t>alert('Validate!')</scrip去掉t>"; }
}
|