ASP.Net實現驗證碼

原文出處:http://www.csdn.net/Develop/Read_Article.asp?Id=22618
上面是原文出處,是VB版!在評論中  cwbboy 給出了C#代碼
自己參考了代碼,實踐了一下!OK記錄一下!
生成圖片的Gif.aspx文件!需要引入以下兩名命名空間!
-----------------------------------start----------------------------------------------
using System.Drawing;
using System.Drawing.Imaging;
private void Page_Load(object sender, System.EventArgs e)
  {
   //
在此處放置用戶代碼以初始化頁面
   //RndNum
是一個自定義函數
   string VNum=RndNum(4); //
這裏的數字4代表顯示的是4位的驗證字符串!
   Session["VNum"]=VNum;
   ValidateCode(VNum);
  }
//
生成圖像函數
  private void ValidateCode(string VNum)
  {
   int Gheight=(int)(VNum.Length * 11.5);
   //gheight
爲圖片寬度,根據字符長度自動更改圖片寬度
   System.Drawing.Bitmap Img = new System.Drawing.Bitmap(Gheight,20);
   Graphics g = Graphics.FromImage(Img);
   g.DrawString(VNum,new System.Drawing.Font("Arial",10),new System.Drawing.SolidBrush(Color.Red),3,3);
   //
在矩形內繪製字串(字串,字體,畫筆顏色,左上x.左上y
   System.IO.MemoryStream ms=new System.IO.MemoryStream();
   Img.Save(ms,System.Drawing.Imaging.ImageFormat.Png);
   Response.ClearContent(); //
需要輸出圖象信息 要修改HTTP
   Response.ContentType="image/Png";
   Response.BinaryWrite(ms.ToArray());
   g.Dispose();
   Img.Dispose();
   Response.End();
  }

//
生成隨機數函數中從Vchar數組中隨機抽取
//
字母區分大小寫
public string RndNum(int VcodeNum)
  {
   string Vchar = "0,1,2,3,4,5,6,7,8,9,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P,Q,R,S,T,U,W,X,Y,Z" ;
   
   string[] VcArray = Vchar.Split(',') ;
   string  VNum = "" ;//
由於字符串很短,就不用StringBuilder
   int temp = -1 ;//
記錄上次隨機數值,儘量避免生產幾個一樣的隨機數<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

   //採用一個簡單的算法以保證生成隨機數的不同
   Random rand =new Random();
   for ( int i = 1 ; i < VcodeNum+1 ; i++ )
   {   
    if ( temp != -1)
    {
     rand =new Random(i*temp*unchecked((int)DateTime.Now.Ticks));
    }   
    //int t =  rand.Next(35) ;
    int t=rand.Next(35);
    if (temp != -1 && temp == t)
    {
     return RndNum( VcodeNum );
    }
    temp = t  ;
    VNum += VcArray[t];

   }
   return VNum ;
  }
-----------------------------------end--------------------------------------------

下面是Login.Aspx在在調用提交按鈕的響應事件中
public void doit(object sender, System.EventArgs e)
  {
   if(Page.IsValid)
   {
     
    string VNum;
    VNum=Session["VNum"].ToString();        
    ViewState["VNum"]=VNum;
    if(this.Vcode.Text==ViewState["VNum"].ToString())
    { 

     Hover.Manage.CheckLogin obj=new Hover.Manage.CheckLogin();
     string name=username.Text;
     string password=FormsAuthentication.HashPasswordForStoringInConfigFile(pass.Text.ToString(),"md5");
     if(!obj.checklogin(name,password))
     {
      Response.Redirect("../Error.aspx?action=Errorlogin");
      Response.End();
      return;
     }
     else
     {
      Session.Add("adminname",name);
      Session.Add("adminpass",password);
      Response.Redirect("Default.aspx");
      Response.End();
      return;
     }
     
    }
    else
    {
     Response.Write("<script>alert(/"
請輸入正確的附加碼!/");</script>");
    }
   }
  }
   
如果提交過來的驗證字符串正確就驗證是否是合法用戶!
否則彈出提示返回登陸頁!你也可以簡化此頁!
   if(this.Vcode.Text==ViewState["VNum"].ToString())
    { 
        Response.Write("
驗證碼正確");
    }
   else
    {
        Response.Write("
驗證碼錯誤!");
    }
-----------------------------------The End<?xml:namespace prefix = v ns = "urn:schemas-microsoft-com:vml" />--------------------------------------------

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章