十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
怎么在Asp.net项目中判断一个session是否合法?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。
创新互联公司-专业网站定制、快速模板网站建设、高性价比德钦网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式德钦网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖德钦地区。费用合理售后完善,10多年实体公司更值得信赖。复制代码 代码如下:
if (Session["UserID"] == "" || Session["UserID"] == null)
{
Response.Redirect("../Login.aspx?m=登录已超时,请重新登陆!");
}
一直我都觉得这个方法很不好,非常不好,但是一直也没找到好的方法,刚才突然就想到和匿名方法,结合??运算符,如果session为空,那么就不合法的了, 可以用来判断用户是否登录。
由于Session["UserID"]返回的是Object类型,如果是空的话,就会报空指针异常,以上面的形式来看,而且,这种判断登录状态的行为,在一些项目中是几乎每个页面都需要用到,所以可以提取出一个方法,与其他公有的静态方法一起放到一个类里面,写成如下形式:
复制代码 代码如下:
///
/// 判断是否登录成功,如果成功则返回session存的字符串,否则为空字符串
///
public static Func
复制代码 代码如下:
if (string.IsNullOrEmpty(isLogin(Session["UserID"])))
{
Response.Redirect("../Login.aspx?m=登录已超时,请重新登陆!");
}
您可以会说为何不直接使用string.IsNullOrEmpty来直接判断Session?那么我告诉你,这就如果Session中没有你进行判断的这个key会直接报空指针异常的。
如果是一个类呢?也很明显,session存储的比如说是一个User类,那么上面对代码就改成这样的形式:
复制代码 代码如下:
public static Func
因为返回的类型是User,所以可以使用一个User类来进行接收返回的值,这样,在后面的操作中可以直接使用了。
复制代码 代码如下:
User _user = isLogin(Session["UserID"]);
if (_user.UserID == -1)
{
//登录失败
}
关于怎么在Asp.net项目中判断一个session是否合法问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注创新互联行业资讯频道了解更多相关知识。