全局验证用户是否登录的机制
利用过滤器的机制进行验证
方法一: 一:建立一个全局处理验证用户是否登录的类LoginCheckFilterAttribute
二:LoginCheckFilterAttribute类 继承于ActionFilterAttribute类 使其据用MVC过滤器的特性
(内容补充:MVC的几种过滤器
四种过滤器:
1:Action过滤器
微软提供的接口IActionFilter
Action方法执行之前和Action方法执行之后执行的东西
2:View视图渲染过滤器
微软提供的接口IResultFilter
在View视图执行之前和View视图执行之后所做的事
3:全局错误异常过滤器
在程序出现错误后所做的事
4:身份验证过滤器
MVC微软自己提供的身份验证不够完善,项目中引用的较少)
三:类中具体代码如下:
public class LoginCheckFilterAttribute:ActionFilterAttribute
{
/// <summary>
/// 检测是否登录全局过滤器 原理:Action过滤器
/// </summary>
public bool IsCheck { get; set; }//IsCheck用于不需要检测的界面
public override void OnActionExecuting(ActionExecutingContext filterContext)
{
base.OnActionExecuting(filterContext);
if (IsCheck)
{
//检测用户是否登录
if (filterContext.HttpContext.Session["LoginUser"]==null)
{
filterContext.HttpContext.Response.Redirect("/UserLogin/Login");
}
}
}
}
四:在Mvc中App_Start 中的FilterConfig注册全局变量方法 代码如下:
//全局检测是否登录过滤器
filters.Add(new LoginCheckFilterAttribute() {IsCheck=true});
五:如果有的页面不需要只需要用如下代码标识即可:
[LoginCheckFilter(IsCheck = false)]
public class UserLoginController : Controller
{
}
方法二:一:建立一个基类控制器 BaseControllers 控制器本身就是一个过滤器 具有过滤器的各种特性
二:BaseController类所继承的Controller类本身就是一个控制器的基类 所以直接Override重写方法
重写Action执行之前操作方法OnActionExecuting 这个控制器就具有了Action过滤验证用户是否登录的功能
public override void OnActionExecuting(ActionExecutingContext filterContext)
{
base.OnActionExecuting(filterContext);
if (IsCheck)
{
//检测用户是否登录
if (filterContext.HttpContext.Session["LoginUser"]==null)
{
filterContext.HttpContext.Response.Redirect("/UserLogin/Login");
}
}
}
三; 需要用户验证的控制器只需要继承该基类控制器即可
转载于:https://www.cnblogs.com/humo/p/6415991.html