前言:设置登录身份验证,并不是严格的权限限制,如果是权限限制就要牵扯到具体的业务逻辑了。而登录身份验证是确定用户是否已经登录,或者在seesion的生命周期内有效!!
无论在做大项目或者小项目时,难免要用到登陆的身份验证。如果是小项目,页面不是很多我们可以在每个页面上做一个省份验证。但是有没有想过,如果页面有上百个或者上千个难道每次都要做身份验证吗?!我想这一定是一件十分痛苦的事情。下面介绍一种一劳永逸的方法:
示例:
首先当用户登录成功后要设置一个session如:HttpContext.Current.Session["userCheck"]=true;
然后重点在下面:
新建一个Web窗体,在这就命名为BasePage.aspx
代码:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
namespace NormalPro
{
public partial class BasePage : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
}
/// <summary>
/// 构造函数
/// </summary>
public BasePage()
{
this.Load += new EventHandler(BasePage_Load);
}
/// <summary>
/// 页面加载时执行验证
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
void BasePage_Load(object sender, EventArgs e)
{
//获取Session,判断用户是否已登录
if (object.Equals(HttpContext.Current.Session["userCheck"], null))
{
//如果用户没有登录或者session超时则跳转到登陆界面
this.Response.Redirect("~/login.aspx");
}
}
}
}
下面就简单了,在你想要用登录身份验证的页面上继承这个BasePage 窗体就行了
如:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
namespace NormalPro
{
public partial class UserSysList : BasePage // 把原来的public partial class UserSysList:: System.Web.UI.Page 改为继承自BagePage即可
{
protected void Page_Load(object sender, EventArgs e)
{
}
}
}
这样你就不用担心有人直接在地址栏上敲路径找你的页面了……-_-
本文介绍了一种在ASP.NET项目中实现统一登录验证的方法。通过设置Session并利用基类页面(BasePage)进行验证,可以避免在每个页面重复验证登录状态,从而简化开发流程。
936

被折叠的 条评论
为什么被折叠?



