今天突然想到一個判斷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 ?? stringEmpty;
Session裡面可以存的Object所以可以是個字符串可以是個數字也可以是一個類或者一個集合我上面這段代碼假定存儲的是一個字符串調用的時候就像是調用方法一樣那個調用這個匿名的方法
復制代碼 代碼如下:
if (string
IsNullOrEmpty(isLogin(Session["UserID"])))
{
Response
Redirect("
/Login
aspx?m=登錄已超時
請重新登陸!");
}
您可以會說為何不直接使用stringIsNullOrEmpty來直接判斷Session?那麼我告訴你這就如果Session中沒有你進行判斷的這個key會直接報空指針異常的
如果是一個類呢?也很明顯session存儲的比如說是一個User類那麼上面對代碼就改成這樣的形式
復制代碼 代碼如下:
public static Func<Object
User> isLogin = session => session as User ?? new User() { UserID =
};
因為返回的類型是User所以可以使用一個User類來進行接收返回的值這樣在後面的操作中可以直接使用了
復制代碼 代碼如下:
User _user = isLogin(Session["UserID"]);
if (_user
UserID ==
)
{
//登錄失敗
}
我不清楚這樣的方式好不好但是我覺得這樣的代碼我讀起來更容易理解操作起來也會方便一些如果您有更好的方法請您不吝指教
From:http://tw.wingwit.com/Article/program/net/201311/14110.html