Asp.net中判断一个session是否合法的方法
2023-06-13 09:15:03 时间
if(Session["UserID"]==""||Session["UserID"]==null)
{
Response.Redirect("../Login.aspx?m=登录已超时,请重新登陆!");
}
一直我都觉得这个方法很不好,非常不好,但是一直也没找到好的方法,刚才突然就想到和匿名方法,结合??运算符,如果session为空,那么就不合法的了,可以用来判断用户是否登录。
由于Session["UserID"]返回的是Object类型,如果是空的话,就会报空指针异常,以上面的形式来看,而且,这种判断登录状态的行为,在一些项目中是几乎每个页面都需要用到,所以可以提取出一个方法,与其他公有的静态方法一起放到一个类里面,写成如下形式:
///<summary>
///判断是否登录成功,如果成功则返回session存的字符串,否则为空字符串
///</summary>
publicstaticFunc<Object,string>isLogin=session=>sessionasstring??string.Empty;
Session里面可以存的Object,所以,可以是个字符串,可以是个数字,也可以是一个类或者一个集合。我上面这段代码假定存储的是一个字符串,调用的时候,就像是调用方法一样那个调用这个匿名的方法:
if(string.IsNullOrEmpty(isLogin(Session["UserID"])))
{
Response.Redirect("../Login.aspx?m=登录已超时,请重新登陆!");
}
您可以会说为何不直接使用string.IsNullOrEmpty来直接判断Session?那么我告诉你,这就如果Session中没有你进行判断的这个key会直接报空指针异常的。
如果是一个类呢?也很明显,session存储的比如说是一个User类,那么上面对代码就改成这样的形式:
publicstaticFunc<Object,User>isLogin=session=>sessionasUser??newUser(){UserID=-1};
因为返回的类型是User,所以可以使用一个User类来进行接收返回的值,这样,在后面的操作中可以直接使用了。
User_user=isLogin(Session["UserID"]);
if(_user.UserID==-1)
{
//登录失败
}
我不清楚这样的方式好不好,但是我觉得这样的代码,我读起来更容易理解,操作起来也会方便一些。如果您有更好的方法,请您不吝指教。
相关文章
- 【特别的骚气】asp.net core运行时注入服务,实现类库热插拔
- 数据库使用 ASP 读取 MySQL 数据库的实现方法(asp读取mysql)
- Net访问Oracle数据库的简易方法(.net访问oracle)
- ASP搭配MySQL使用的缺点及解决办法(asp使用mysql缺点)
- ASP.net中md5加密码的方法
- asp.net下URL处理两个小工具方法
- ASP.NET跨页面传值方法
- asp.net程序在调式和发布之间图片路径问题的解决方法
- asp.net提高网站速度及如何利用缓存
- asp.net该行已经属于另一个表错误的解决方法
- asp.net通过httpModule计算页面的执行时间
- 在asp.net(c#)下实现调用cmd的方法
- asp.net数字签名实例代码
- asp.net组合模式的一个例子
- Asp.net之TextBox只允许输入数字的方法总结
- asp.net中将js的返回值赋给asp.net控件的小例子
- ASP.NET加密口令的方法实例
- asp.net图片超过指定大小后等比例压缩图片的方法
- ASP.NET在下载文件时对其重命名的思路及实现方法
- asp.net如何得到GRIDVIEW中某行某列值的方法
- asp.net中几种常用的身份验证方法总结
- ASP.NET刷新页面的几种方法详解
- asp.net中TextBox只能输入数字的最简洁的两种方法
- 刷新页面的几种方法小结(JS,ASP.NET)
- ASP.NET页面按钮单击事件失效的解决方法
- asp.net实现word文档在线预览功能的方法
- ASP.NET网站实时显示时间的方法
- Asp.net配合easyui实现返回json数据实例
- asp.net中button控制先执行js再执行后台程序的方法