【发布时间】:2017-09-30 02:50:21
【问题描述】:
目前我正在覆盖 autofac boostrapper 中的应用程序启动以添加到下面的标题中。
protected override void ApplicationStartup(ILifetimeScope container, IPipelines pipelines)
{
pipelines.AfterRequest.AddItemToEndOfPipeline(ctx =>
{
ctx.Response
.WithHeader("Access-Control-Allow-Origin", "*")
.WithHeader("Access-Control-Allow-Methods", "GET, POST, PUT, DELETE, OPTIONS")
.WithHeader("Access-Control-Allow-Headers", "Accept, Origin, Content-Type, Authorization");
});
base.ApplicationStartup(container, pipelines);
}
在所有主要路线上,标头都已正确附加。但是,当从 chrome、postman 或 fiddler 发送 OPTIONS 飞行前请求时,不会附加标头。
这是一个典型的 get 调用:
这是浏览器请求
现在在浏览器请求中,我返回了错误的允许集。
就上下文而言,我目前正在使用 clinteastwood 版本,但在稳定版本中也有这个。我正在利用 AutofacBootstrapper、Owin 和 Owin.StatelessAuth。
我也尝试安装Microsoft.Owin.Cors 并使用app.UseCors(CorsOptions.AllowAll); 没有成功
我显然做错了什么,我只是不确定是什么......
谁能解释这种行为?
【问题讨论】:
-
web.config 中是否有任何内容可以更改允许标头?
-
是的,我可以通过配置轻松添加标题,但对这种行为的原因感到好奇。