asp.net-mvc – 在自定义授权属性中覆盖AuthorizeCore导致“找不到适当的方法覆盖”错误

前端之家收集整理的这篇文章主要介绍了asp.net-mvc – 在自定义授权属性中覆盖AuthorizeCore导致“找不到适当的方法覆盖”错误前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在尝试构建自定义的AuthorizeAttribute,所以在我的Core项目(一个类库)中,我有这个代码
using System;
using System.Web;
using System.Web.Mvc;
using IVC.Core.Web;
using System.Linq;

namespace IVC.Core.Attributes
{
    public class TimeShareAuthorizeAttribute : AuthorizeAttribute
    {
        protected override bool AuthorizeCore(HttpContextBase httpContext)
        {
            if(!httpContext.Request.IsAuthenticated)
                return false;

            var rolesProvider = System.Web.Security.Roles.Providers["TimeShareRoleProvider"];

            string[] roles = rolesProvider.GetRolesForUser(httpContext.User.Identity.Name);

            if(roles.Contains(Website.Roles.RegisteredClient,StringComparer.OrdinalIgnoreCase))
            {
                return true;
            }

            return false;
        }

        protected override void HandleUnauthorizedRequest(AuthorizationContext filterContext)
        {
            filterContext.Result = new RedirectResult("/TimeShare/Account/logon");

            base.HandleUnauthorizedRequest(filterContext);
        }
    }
}

当我尝试构建的东西我得到这个错误
错误2’IVC.Core.Attributes.TimeShareAuthorizeAttribute.AuthorizeCore(System.Web.HttpContextBase)’:找不到合适的方法覆盖…

我在这里缺少什么?我已经搜索过,但我可以找到的每个网站只是告诉我做我在这里做的。我正在使用mvc2 btw。

>编辑添加:如果我在同一个解决方案中将类移动到mvc项目,那么就没有编译错误

解决方法

是的,我摸索了一个一会儿,并从对象浏览器中找出来。除非您一直滚动到HttpContextBase类上的用户评论,否则MSDN文档当然不清楚。当然,网络上有很多例子,但没有人会显示完整的类文件

猜你在找的asp.Net相关文章