mvc3 action验证失败后的自定义处理


我们知道,要在一个action前加上权限的限制就要特性比如拥有admin权限的用户就加上

[Authorize(Roles="admin")]

给每个登陆用户分配权限则是要在Global.asax.cs中加上这两个函数

        public MvcApplication()
        {
            AuthorizeRequest += new EventHandler(MvcApplication_AuthorizeRequest);
        }

        void MvcApplication_AuthorizeRequest(object sender, EventArgs e)
        {
            IIdentity id = Context.User.Identity;
            if (id.IsAuthenticated)
            {
                var roles = new string[] { "admin", "reg" };
                //string[] rolelist = new string[] { roles.Name };
                Context.User = new GenericPrincipal(id, roles);
            }
        }

当权限验证失败时,mvc默认跳转到登陆页面,如果我们要改变这一设置就要重载Attribute 类:System.Web.Mvc.AuthorizeAttribute的HandleUnauthorizedRequest函数

比如发生错误的时候跳转到新浪首页:

    public class MyAuth : System.Web.Mvc.AuthorizeAttribute
    {
        protected override void HandleUnauthorizedRequest(AuthorizationContext filterContext)
        {
            //base.HandleUnauthorizedRequest(filterContext);
            filterContext.HttpContext.Response.Redirect("http://www.sina.com");
        }
    }
别忘了在action前面加上自己定义的权限特性:

[MyAuth(Roles = "admin")]


posted @ 2012-10-09 12:22  爱知菜  阅读(255)  评论(0编辑  收藏  举报