認証コードの編集方法
23233 ワード
asp.Netでは、登録インタフェースを設計するには検証コードが必要になります.次に、検証コードの実現過程を書きます.その中の一部のコードは先生がくれたものです.まず、ランダムに生成された数字を画像に変え、ノイズを加えるファイルが必要です.
イメージのURLに上記のファイルをインポートするパスでは、検証コードには1枚の操作を変更する必要があることを知っています.ここでjsコード実装を追加します.
画像の横に「交換」ボタンを追加します.
検証コードと検証コードの交換が可能になりました
using System;
using System.Collections;
using System.Data;
using System.Linq;
using System.Web;
using System.Web.Services;
using System.Web.Services.Protocols;
using System.Xml.Linq;
using System.Drawing;
using System.Web.SessionState;
namespace snyDrugs.MainWeb
{
///
/// $codebehindclassname$
///
[WebService(Namespace = "http://tempuri.org/")]
[WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
public class VerifyCode : IHttpHandler, IRequiresSessionState
{
public void ProcessRequest(HttpContext context)
{
VerifyCode v = new VerifyCode();
v.Length = 5;
v.FontSize = 15;
v.Chaos = true;
v.BackgroundColor = this.backgroundColor;
v.ChaosColor = this.chaosColor;
v.CodeSerial = this.codeSerial;
v.Colors = this.colors;
v.Fonts = this.fonts;
v.Padding = this.padding;
string code = v.CreateVerifyCode();
v.CreateImageOnPage(code, context);
context.Session["CheckCode"] = code; // Session
// context.Response.Write(context.Session["CheckCode"]);
}
public bool IsReusable
{
get
{
return false;
}
}
#region ( 6 )
int length = 6;
public int Length
{
get
{
return length;
}
set
{
length = value;
}
}
#endregion
#region ( , 40 , )
int fontSize = 40;
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 = "1,2,3,4,5,6,7,8,a,b,c,d,e,f,h,j,k,m,n,p,q,r,s,t,u,v,w,x,y,z,A,B,C,D,E,F,G,H,K,M,N,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;
///
/// Wave (Edit By 51aspx.com)
///
///
/// True
/// , , 3
/// , [0-2*PI)
///
public System.Drawing.Bitmap TwistImage(Bitmap srcBmp, bool bXDir, double dMultValue, double dPhase)
{
System.Drawing.Bitmap destBmp = new Bitmap(srcBmp.Width, srcBmp.Height);
//
System.Drawing.Graphics graph = System.Drawing.Graphics.FromImage(destBmp);
graph.FillRectangle(new SolidBrush(System.Drawing.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, 2, 4);
return image;
}
#endregion
#region
public void CreateImageOnPage(string code, HttpContext context)
{
System.IO.MemoryStream ms = new System.IO.MemoryStream();
Bitmap image = this.CreateImageCode(code);
image.Save(ms, System.Drawing.Imaging.ImageFormat.Jpeg);
context.Response.ContentType = "image/Jpeg";
context.Response.BinaryWrite(ms.GetBuffer());
ms.Close();
ms = null;
image.Dispose();
image = null;
}
#endregion
#region
public string CreateVerifyCode(int codeLen)
{
if (codeLen == 0)
{
codeLen = Length;
}
string[] arr = CodeSerial.Split(',');
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
}
}
生成了图片时,需要将图片引进到项目中
<asp:Image ID="Img_yzm" runat="server"
ImageUrl="~/VerifyCode.ashx" />
イメージのURLに上記のファイルをインポートするパスでは、検証コードには1枚の操作を変更する必要があることを知っています.ここでjsコード実装を追加します.
<script language="javascript" type="text/javascript">
function getimgcode() {
var randomnum = Math.random();
var getimagecode = document.getElementById("Img_yzm");
getimagecode.src = " VerifyCode.ashx?" + Math.random();
}
script>
画像の横に「交換」ボタンを追加します.
input name="buton" id="button1" type="button" value=" " b
onclick = "getimgcode() " style="background-color: #FF6600" />
検証コードと検証コードの交換が可能になりました