首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Web api开发时授权属性禁用

Web api开发时授权属性禁用
EN

Stack Overflow用户
提问于 2017-11-07 16:54:06
回答 1查看 152关注 0票数 1

我正在使用授权的控制器操作,其中一些操作是基于角色的。

代码语言:javascript
复制
    [Authorize(Roles = "SuperUsers")]
    public class UserGroupController : ApiController
    {
        private readonly MyContext context = new MyContext();

        [HttpGet]
        public async Task<IHttpActionResult> Get()
        {
           .......
        }
    }

当我想使用这个控制器时,我的请求返回401条未经授权的消息。

因此,我创建了一个Authrization属性来禁用它,如下所示:

代码语言:javascript
复制
public class DevelopmentAuthorizationFilter:AuthorizeAttribute
{
    protected override bool IsAuthorized(HttpActionContext actionContext)
    {
        return actionContext.Request.RequestUri.IsLoopback || base.IsAuthorized(actionContext);
    }
}

我把它添加到了HttpConfiguration过滤器中。

代码语言:javascript
复制
    public void Configuration(IAppBuilder app)
    {
        var configuration = new HttpConfiguration();
        .............
        configuration.Filters.Add(new DevelopmentAuthorizationFilter());
    }

但它不起作用。我该如何解决这个问题呢?

EN

回答 1

Stack Overflow用户

发布于 2017-11-08 04:39:53

您对控制器应用了两个授权过滤器。全局级别的DevelopmentAuthorizationFilter (已传递)和控制器级别的AuthorizeAttribute (未传递)。因此,只在控制器级别使用DevelopmentAuthorizationFilter就可以解决这个问题。

代码语言:javascript
复制
[DevelopmentAuthorizationFilter(Roles = "SuperUsers")]
public class UserGroupController : ApiController
{

}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/47153586

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档