Quando projetamos o módulo de login do usuário, geralmente usamos códigos de verificação, que podem prevenir efetivamente o cracking malicioso por software hacker. Agora divulgarei o código-fonte dos meus códigos de verificação comumente usados.
Como usar:
1. Adicione uma classe ao projeto da Web, como "CreateImage.cs", e copie o código-fonte que publiquei nela;
2. Crie um novo formulário Web, como "Image.aspx", e adicione o código "CreateImage.DrawImage ();" em Page_Load. Claro, não se esqueça de adicionar uma referência à classe! !
3. Adicione o seguinte código javascript à posição apropriada na página (onde você deseja colocar o código de verificação) e está tudo bem.
O código fonte é o seguinte:
///
///Módulo de código de verificação ///
classe pública CreateImage
{
público estático vazio DrawImage()
{
CriarImagem img=new CriarImagem();
HttpContext.Current.Session["CheckCode"]=img.RndNum(4);
img.CreateImages(HttpContext.Current.Session["CheckCode"].ToString());
}
///
/// Gera imagem de verificação ///
/// Verifica os caracteres private void CreateImages(string checkCode)
{
int ilargura = (int)(checkCode.Length * 13);
Imagem System.Drawing.Bitmap = novo System.Drawing.Bitmap (iwidth, 23);
Gráficos g = Graphics.FromImage(imagem);
g.Claro(Cor.Branco);
//Definir cor Color[] c = {Color.Black,Color.Red,Color.DarkBlue,Color.Green,Color.Orange,Color.Brown,Color.DarkCyan,Color.Purple};
//Definir fonte string[] font = {"Verdana","Microsoft Sans Serif","Comic Sans MS","Arial","宋体"};
Rand aleatório = new Random();
//Saída aleatória de pontos de ruído for(int i=0;i<50;i++)
{
int x = rand.Next(imagem.Largura);
int y = rand.Next(imagem.Altura);
g.DrawRectangle(nova Caneta(Color.LightGray, 0),x,y,1,1);
}
//Sai caracteres do código de verificação em diferentes fontes e cores for(int i=0;i
{
int cindex = rand.Next(7);
int findex = rand.Next(5);
Fonte f = new System.Drawing.Font(font[findex], 10, System.Drawing.FontStyle.Bold);
Pincel b = novo System.Drawing.SolidBrush(c[cindex]);
intii=4;
se((eu+1)%2==0)
{
ii=2;
}
g.DrawString(checkCode.Substring(i,1), f, b, 3+(i*12), ii);
}
//Desenha uma borda g.DrawRectangle(new Pen(Color.Black,0),0,0,image.Width-1,image.Height-1);
//Saída para o navegador System.IO.MemoryStream ms = new System.IO.MemoryStream();
imagem.Save(ms,System.Drawing.Imaging.ImageFormat.Jpeg);
HttpContext.Current.Response.ClearContent();
//Response.ClearContent();
HttpContext.Current.Response.ContentType = "imagem/Jpeg";
HttpContext.Current.Response.BinaryWrite(ms.ToArray());
g.Dispose();
imagem.Dispose();
}
///
/// Gera letras aleatórias ///
/// Número de letras geradas /// string
string privada RndNum(int VcodeNum)
{
string Vchar = "0,1,2,3,4,5,6,7,8,9";
string[] VcArray = Vchar.Split(',') ;
string VNum = "" ; // Como a string é muito curta, StringBuilder não é necessário int temp = -1 ; // Registre o último valor aleatório e tente evitar a produção de vários números aleatórios idênticos // Use um algoritmo simples para garantir a geração; números aleatórios diferentes Rand aleatório =new Random();
for ( int i = 1 ; i < VcodeNum+1 ; i++ )
{
se (temperatura! = -1)
{
rand =new Random(i*temp*unchecked((int)DateTime.Now.Ticks));
}
int t = rand.Next(VcArray.Length );
if (temperatura! = -1 && temp == t)
{
retornar RndNum(VcodeNum);
}
temperatura = t;
VNum += VcArray[t];
}
retornar VNum;
}