您好,登錄后才能下訂單哦!
怎么在Asp.net項目中判斷一個session是否合法?針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
復制代碼 代碼如下:
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)
{
//登錄失敗
}
關于怎么在Asp.net項目中判斷一個session是否合法問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。