今天突然想到一个判断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 ==
)
{
//登录失败
}
我不清楚这样的方式好不好但是我觉得这样的代码我读起来更容易理解操作起来也会方便一些如果您有更好的方法请您不吝指教