이 글은 기계 번역의 미러 문서이며, 원본 기사로 바로 이동하려면 여기를 클릭해 주세요.

보기: 18594|회답: 1

[ASP.NET] asp.net 이미지 캡차 생성의 원칙과 코드

[링크 복사]
게시됨 2015. 4. 2. 오전 10:26:51 | | |
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>"; }
}




이전의:IE는 원격 명령 실행을 종료합니다
다음:asp.net 값을 저장하는 쿠키를 구현합니다
게시됨 2015. 4. 4. 오전 10:58:42 |
이미 쓸 수 있어요
면책 조항:
Code Farmer Network에서 발행하는 모든 소프트웨어, 프로그래밍 자료 또는 기사는 학습 및 연구 목적으로만 사용됩니다; 위 내용은 상업적 또는 불법적인 목적으로 사용되지 않으며, 그렇지 않으면 모든 책임이 사용자에게 부담됩니다. 이 사이트의 정보는 인터넷에서 가져온 것이며, 저작권 분쟁은 이 사이트와는 관련이 없습니다. 위 내용은 다운로드 후 24시간 이내에 컴퓨터에서 완전히 삭제해야 합니다. 프로그램이 마음에 드신다면, 진짜 소프트웨어를 지원하고, 등록을 구매하며, 더 나은 진짜 서비스를 받아주세요. 침해가 있을 경우 이메일로 연락해 주시기 바랍니다.

Mail To:help@itsvse.com