【发布时间】:2020-07-16 22:08:18
【问题描述】:
我正在尝试根据应用程序运行的环境在我的 CORS 策略之间“切换”。
我有两个政策声明如下:
services.AddCors(options =>
{
options.AddPolicy(CORSPolicies.PublicApi,
builder => builder
.AllowAnyHeader()
.WithMethods("POST", "GET")
.WithOrigins("https://domain1.com", "https://domain2.com"));
options.AddPolicy(CORSPolicies.Dev,
builder => builder
.AllowAnyHeader()
.AllowAnyMethod()
.AllowAnyOrigin());
});
这些策略应该只适用于少数控制器,所以我使用属性来应用它们:
[ApiController]
[Route("api/[controller]")]
[Produces("application/json")]
[AllowAnonymous]
[EnableCors(CORSPolicies.PublicApi)]
public class PublicApiControllerBase : ControllerBase
{
}
PublicAPI 策略应该对域将实际受到限制的生产有效。 Dev 政策允许任何事情,因为我将在本地使用它。
我尝试在应用程序启动时有条件地将默认策略设置为Dev,但由于EnableCorsAttribute 覆盖了app.UseCors() 定义的内容,因此它不起作用,因为无论如何都会使用PublicApi 策略.这是我天真的尝试:
if (env.IsDevelopment())
{
app.UseCors(CORSPolicies.Dev);
}
else
{
app.UseCors();
}
我如何 a) 使我的 PublicApi 策略的行为根据我的应用运行的环境有所不同,或者 b) 有条件地应用 PublicApi 或 Dev 策略,具体取决于环境?
【问题讨论】:
标签: c# asp.net-core cors asp.net-core-3.1