欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Asp.net中判断一个session是否合法的方法

程序员文章站 2024-03-01 17:10:28
复制代码 代码如下: if (session["userid"] == "" || session["userid"] == null) { ...
复制代码 代码如下:

 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)
 {
     //登录失败
 }

我不清楚这样的方式好不好,但是我觉得这样的代码,我读起来更容易理解,操作起来也会方便一些。如果您有更好的方法,请您不吝指教。