程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> ASP.NET >> 關於ASP.NET >> Asp.net中判斷一個session是否合法的方法

Asp.net中判斷一個session是否合法的方法

編輯:關於ASP.NET
    今天突然想到一個判斷session是否合法的做法,asp.net的,之前我們的做法是下面這樣的形式的:   復制代碼 代碼如下:
     if (Session["UserID"] == "" || Session["UserID"] == null)
     {
         Response.Redirect("../Login.aspx?m=登錄已超時,請重新登陸!");
     }


    一直我都覺得這個方法很不好,非常不好,但是一直也沒找到好的方法,剛才突然就想到和匿名方法,結合??運算符,如果session為空,那麼就不合法的了, 可以用來判斷用戶是否登錄。
    由 於Session["UserID"]返回的是Object類型,如果是空的話,就會報空指針異常,以上面的形式來看,而且,這種判斷登錄狀態的行為,在 一些項目中是幾乎每個頁面都需要用到,所以可以提取出一個方法,與其他公有的靜態方法一起放到一個類裡面,寫成如下形式:

    復制代碼 代碼如下:
     /// <summary>
     /// 判斷是否登錄成功,如果成功則返回session存的字符串,否則為空字符串
     /// </summary>


    public static Func<Object, string> isLogin = session => session as string ?? string.Empty;
    Session裡面可以存的Object,所以,可以是個字符串,可以是個數字,也可以是一個類或者一個集合。我上面這段代碼假定存儲的是一個字符串,調用的時候,就像是調用方法一樣那個調用這個匿名的方法:

    復制代碼 代碼如下:
     if (string.IsNullOrEmpty(isLogin(Session["UserID"])))
     {
         Response.Redirect("../Login.aspx?m=登錄已超時,請重新登陸!");
     }


    您可以會說為何不直接使用string.IsNullOrEmpty來直接判斷Session?那麼我告訴你,這就如果Session中沒有你進行判斷的這個key會直接報空指針異常的。
    如果是一個類呢?也很明顯,session存儲的比如說是一個User類,那麼上面對代碼就改成這樣的形式:

    復制代碼 代碼如下:
     public static Func<Object, User> isLogin = session => session as User ?? new User() { UserID = -1};


    因為返回的類型是User,所以可以使用一個User類來進行接收返回的值,這樣,在後面的操作中可以直接使用了。

    復制代碼 代碼如下:
     User _user = isLogin(Session["UserID"]);
     if (_user.UserID == -1)
     {
         //登錄失敗
     }


    我不清楚這樣的方式好不好,但是我覺得這樣的代碼,我讀起來更容易理解,操作起來也會方便一些。如果您有更好的方法,請您不吝指教。

    1. 上一頁:
    2. 下一頁:
    Copyright © 程式師世界 All Rights Reserved