思路:
一.登陸時為每個用戶保存一個唯一ID號,處理頁判斷ID異同。代碼:
登陸頁login.aspx.cs:
 protected void Button1_Click(object sender, EventArgs e)
protected void Button1_Click(object sender, EventArgs e)
 {
    {
 Session["name"] = TextBox1.Text;
        Session["name"] = TextBox1.Text;
 if (Cache["userlist"] == null)
        if (Cache["userlist"] == null)
 {
        {
 System.Collections.Generic.Dictionary<string,string> userlist = new System.Collections.Generic.Dictionary<string,string>();
            System.Collections.Generic.Dictionary<string,string> userlist = new System.Collections.Generic.Dictionary<string,string>();
 userlist.Add(Session["name"].ToString(), Session.SessionID);
            userlist.Add(Session["name"].ToString(), Session.SessionID);
 Cache["userlist"] = userlist;
            Cache["userlist"] = userlist;
 }
        }
 else
        else
 {
        {
 System.Collections.Generic.Dictionary<string, string> userlist = Cache["userlist"] as System.Collections.Generic.Dictionary<string, string>;
            System.Collections.Generic.Dictionary<string, string> userlist = Cache["userlist"] as System.Collections.Generic.Dictionary<string, string>;
 userlist[Session["name"].ToString()] = Session.SessionID;
            userlist[Session["name"].ToString()] = Session.SessionID;
 Cache["userlist"] = userlist;
            Cache["userlist"] = userlist;
 }
        }
 Response.Redirect("default.aspx");
        Response.Redirect("default.aspx");
 }
處理頁default.aspx.cs:
    }
處理頁default.aspx.cs:
 protected void Page_Load(object sender, EventArgs e)
    protected void Page_Load(object sender, EventArgs e)
 {
    {
 if (Session["name"] == null)
        if (Session["name"] == null)
 Response.Write("<script>alert('请登陆');location.href='login.aspx';</script>");
            Response.Write("<script>alert('请登陆');location.href='login.aspx';</script>");
 else if((Cache["userlist"] as System.Collections.Generic.Dictionary<string, string>)[Session["name"].ToString()]!= Session.SessionID)
        else if((Cache["userlist"] as System.Collections.Generic.Dictionary<string, string>)[Session["name"].ToString()]!= Session.SessionID)
 Response.Write("<script>alert('已经有相同帐号登陆');location.href='login.aspx';</script>");
            Response.Write("<script>alert('已经有相同帐号登陆');location.href='login.aspx';</script>");

 }
    }
二.用戶表加登陸次數列,登陸時查詢用戶登錄次數並保存到COOKIE,處理頁查詢登陸次數並與COOKIE比較,不一致説明已被踢出。

 -- =============================================
-- =============================================
 -- Author:    Caviare
-- Author:    Caviare 
 -- Create date:    2006/4/13
-- Create date:    2006/4/13
 -- Description:    查詢目前使用者的登入的SESSION ID
-- Description:    查詢目前使用者的登入的SESSION ID
 --              讓系統能夠防止使用者重複登入
--              讓系統能夠防止使用者重複登入
 -- =============================================
-- =============================================
 CREATE PROCEDURE [dbo].[SP_GET_SESSION_ID]
CREATE PROCEDURE [dbo].[SP_GET_SESSION_ID] 
 -- Add the parameters for the stored procedure here
    -- Add the parameters for the stored procedure here
 @ACCOUNT VARCHAR(20),        --要查詢的帳號
     @ACCOUNT VARCHAR(20),        --要查詢的帳號 
 @SESSION  int output          --登入次數
    @SESSION  int output          --登入次數
 AS
AS
 BEGIN
BEGIN
 -- SET NOCOUNT ON added to prevent extra result sets from
    -- SET NOCOUNT ON added to prevent extra result sets from
 -- interfering with SELECT statements.
    -- interfering with SELECT statements.
 SET NOCOUNT ON;
    SET NOCOUNT ON;
 
 
 set @SESSION=0  --登入次數的預設值
   set @SESSION=0  --登入次數的預設值

 
  
 select @SESSION=isnull(SESSION,0)
       select @SESSION=isnull(SESSION,0)
 from dbo.BSS_USER_DATA
              from dbo.BSS_USER_DATA 
 where  ACCOUNT_ID=@ACCOUNT   -- and  PASSWORD=@PASSWORD
              where  ACCOUNT_ID=@ACCOUNT   -- and  PASSWORD=@PASSWORD
 set @SESSION =isnull(@SESSION,0)
    set @SESSION =isnull(@SESSION,0)
 
   
 
  
 END
END
 GO
GO
 
一.登陸時為每個用戶保存一個唯一ID號,處理頁判斷ID異同。代碼:
登陸頁login.aspx.cs:
 protected void Button1_Click(object sender, EventArgs e)
protected void Button1_Click(object sender, EventArgs e) {
    { Session["name"] = TextBox1.Text;
        Session["name"] = TextBox1.Text; if (Cache["userlist"] == null)
        if (Cache["userlist"] == null) {
        { System.Collections.Generic.Dictionary<string,string> userlist = new System.Collections.Generic.Dictionary<string,string>();
            System.Collections.Generic.Dictionary<string,string> userlist = new System.Collections.Generic.Dictionary<string,string>(); userlist.Add(Session["name"].ToString(), Session.SessionID);
            userlist.Add(Session["name"].ToString(), Session.SessionID); Cache["userlist"] = userlist;
            Cache["userlist"] = userlist; }
        } else
        else {
        { System.Collections.Generic.Dictionary<string, string> userlist = Cache["userlist"] as System.Collections.Generic.Dictionary<string, string>;
            System.Collections.Generic.Dictionary<string, string> userlist = Cache["userlist"] as System.Collections.Generic.Dictionary<string, string>; userlist[Session["name"].ToString()] = Session.SessionID;
            userlist[Session["name"].ToString()] = Session.SessionID; Cache["userlist"] = userlist;
            Cache["userlist"] = userlist; }
        } Response.Redirect("default.aspx");
        Response.Redirect("default.aspx"); }
    } protected void Page_Load(object sender, EventArgs e)
    protected void Page_Load(object sender, EventArgs e) {
    { if (Session["name"] == null)
        if (Session["name"] == null) Response.Write("<script>alert('请登陆');location.href='login.aspx';</script>");
            Response.Write("<script>alert('请登陆');location.href='login.aspx';</script>"); else if((Cache["userlist"] as System.Collections.Generic.Dictionary<string, string>)[Session["name"].ToString()]!= Session.SessionID)
        else if((Cache["userlist"] as System.Collections.Generic.Dictionary<string, string>)[Session["name"].ToString()]!= Session.SessionID) Response.Write("<script>alert('已经有相同帐号登陆');location.href='login.aspx';</script>");
            Response.Write("<script>alert('已经有相同帐号登陆');location.href='login.aspx';</script>");
 }
    }二.用戶表加登陸次數列,登陸時查詢用戶登錄次數並保存到COOKIE,處理頁查詢登陸次數並與COOKIE比較,不一致説明已被踢出。

 -- =============================================
-- ============================================= -- Author:    Caviare
-- Author:    Caviare  -- Create date:    2006/4/13
-- Create date:    2006/4/13 -- Description:    查詢目前使用者的登入的SESSION ID
-- Description:    查詢目前使用者的登入的SESSION ID --              讓系統能夠防止使用者重複登入
--              讓系統能夠防止使用者重複登入 -- =============================================
-- ============================================= CREATE PROCEDURE [dbo].[SP_GET_SESSION_ID]
CREATE PROCEDURE [dbo].[SP_GET_SESSION_ID]  -- Add the parameters for the stored procedure here
    -- Add the parameters for the stored procedure here @ACCOUNT VARCHAR(20),        --要查詢的帳號
     @ACCOUNT VARCHAR(20),        --要查詢的帳號  @SESSION  int output          --登入次數
    @SESSION  int output          --登入次數 AS
AS BEGIN
BEGIN -- SET NOCOUNT ON added to prevent extra result sets from
    -- SET NOCOUNT ON added to prevent extra result sets from -- interfering with SELECT statements.
    -- interfering with SELECT statements. SET NOCOUNT ON;
    SET NOCOUNT ON; 
  set @SESSION=0  --登入次數的預設值
   set @SESSION=0  --登入次數的預設值
 
   select @SESSION=isnull(SESSION,0)
       select @SESSION=isnull(SESSION,0) from dbo.BSS_USER_DATA
              from dbo.BSS_USER_DATA  where  ACCOUNT_ID=@ACCOUNT   -- and  PASSWORD=@PASSWORD
              where  ACCOUNT_ID=@ACCOUNT   -- and  PASSWORD=@PASSWORD set @SESSION =isnull(@SESSION,0)
    set @SESSION =isnull(@SESSION,0) 
    
   END
END GO
GO
 
                    
                     
                    
                 
                    
                 
 
    
 
         
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号