如何在ASP.NET Core中添加全局`AuthorizeFilter`或`AuthorizeAttribute`? [英] How to add global `AuthorizeFilter` or `AuthorizeAttribute` in ASP.NET Core?

查看:299
本文介绍了如何在ASP.NET Core中添加全局`AuthorizeFilter`或`AuthorizeAttribute`?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

ASP.NET MVC 4 及以下版本中,我们只需在Global.asax中添加以下内容:

In ASP.NET MVC 4 and below we just add the following in Global.asax:

GlobalFilters.Filters.Add(new AuthorizeAttribute() { Roles = "Admin, SuperUser" });

是否知道如何在 ASP.NET Core MVC 中执行此操作?

Any idea how to do this in ASP.NET Core MVC?

推荐答案

来自

您可以全局注册过滤器(适用于所有控制器和操作) 通过将其添加到 Startup类中的ConfigureServices方法:

You can register a filter globally (for all controllers and actions) by adding it to the MvcOptions.Filters collection in the ConfigureServices method in the Startup class:

您不能将AuthorizeAttribute添加到MvcOptions.Filters中.创建AuthorizationPolicy并使用AuthorizeFilter:

You can not add AuthorizeAttribute into MvcOptions.Filters . Create an AuthorizationPolicy and use AuthorizeFilter:

var policy = new AuthorizationPolicyBuilder()
        .RequireAuthenticatedUser()
        .RequireRole("Admin", "SuperUser")
        .Build();

services.AddMvc(options =>
{
    options.Filters.Add(new AuthorizeFilter(policy));
});

这篇关于如何在ASP.NET Core中添加全局`AuthorizeFilter`或`AuthorizeAttribute`?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆