using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using PetsStore.Models;
using PetsStore.EntitiesRepositories;

namespace PetsStore.Filters
{
    public class AdminAttribute:AuthorizeAttribute
    {
        private UserRepository userRepository = new UserRepository();
        protected override bool AuthorizeCore(HttpContextBase httpContext)
        {
            if (!httpContext.User.Identity.IsAuthenticated)
            {
                return false;
            }
            var userName=httpContext.User.Identity.Name;
            User user = userRepository.GetByUserName(userName);
            if (!Roles.Contains(user.Role.RoleName))
            {
                return false;
            }
            return true;
        }
        protected override void HandleUnauthorizedRequest(AuthorizationContext filterContext)
        {
            if (!filterContext.HttpContext.User.Identity.IsAuthenticated)
            {
                filterContext.Result = new RedirectResult(string.Format("/Account/AdminLogin?ReturnUrl={0}/{1}", filterContext.RouteData.Values["controller"], filterContext.RouteData.Values["action"]));
            }
            else
            {
                filterContext.Result = new ContentResult() { Content = "对不起,您的权限不足!" };
            }

        }
    }
}

相关文章:

  • 2021-09-23
  • 2021-11-17
  • 2021-07-12
  • 2022-12-23
  • 2022-01-14
  • 2022-12-23
  • 2022-12-23
  • 2022-01-06
猜你喜欢
  • 2021-11-10
  • 2022-12-23
  • 2021-09-09
  • 2022-03-04
  • 2021-07-25
  • 2022-12-23
  • 2021-08-27
相关资源
相似解决方案