MVC身份认证 解决办法 测试可行

这个方法还有点不太完善,个人觉得或许可能有更好的办法。

但是现在还不知道,看到这种留个记录。

 

首先在项目根目录创建文件夹Filter

然后创建BasicAuthAttribute.cs 类文件

代码如下:

 public class BasicAuthAttribute : ActionFilterAttribute
    {
        public override void OnActionExecuting(ActionExecutingContext filterContext)
        {
            var username = filterContext.HttpContext.Session["username"];
            var password = filterContext.HttpContext.Session["password"];
            if (username == null || password == null)

            {
                //用户不登陆的时候跳转到登录页面
                filterContext.Result = new RedirectToRouteResult(new RouteValueDictionary(new { controller = "Home", action = "Login", area = string.Empty }));
            }
        }
    }

 

继承于ActionFilterAttribute,而后调用的时候在项目的控制器以特性的方式来使用

 

当用户没有登录的时候默认进入 Home Login页面。

 [AttributeUsage(AttributeTargets.Class | AttributeTargets.Method, Inherited = true, AllowMultiple = false)]
    public abstract class ActionFilterAttribute : FilterAttribute, IActionFilter, IResultFilter
    {
        protected ActionFilterAttribute();
        //    在Action执行之后由 MVC 框架调用。
        public virtual void OnActionExecuted(ActionExecutedContext filterContext);
        //     在Action执行之前由 MVC 框架调用。
        public virtual void OnActionExecuting(ActionExecutingContext filterContext);
        //     在执行Result后由 MVC 框架调用。
        public virtual void OnResultExecuted(ResultExecutedContext filterContext);
        //     在执行Result之前由 MVC 框架调用。
        public virtual void OnResultExecuting(ResultExecutingContext filterContext);
    }

 

如不明白请参考 源地址:http://www.cnblogs.com/liuxinxin/articles/2265672.html

 

posted @ 2017-06-25 23:00  段十八丶  阅读(167)  评论(0编辑  收藏  举报