gpt4 book ai didi

asp.net-web-api - 未为预检 CORS 请求调用 WebApi DelegatingHandler

转载 作者:行者123 更新时间:2023-12-04 08:39:49 26 4
gpt4 key购买 nike

我正在尝试为我的 WebApi Controller 实现 CORS 支持,并且我正在遵循示例 here .

我的处理程序看起来像这样:

/// <summary>
/// Taken from http://blogs.msdn.com/b/carlosfigueira/archive/2012/02/20/implementing-cors-support-in-asp-net-web-apis.aspx
/// </summary>
public class CorsHandler : DelegatingHandler
{
private const string Origin = "Origin";
private const string AccessControlRequestMethod = "Access-Control-Request-Method";
private const string AccessControlRequestHeaders = "Access-Control-Request-Headers";
private const string AccessControlAllowOrigin = "Access-Control-Allow-Origin";
private const string AccessControlAllowMethods = "Access-Control-Allow-Methods";
private const string AccessControlAllowHeaders = "Access-Control-Allow-Headers";
private const string AccessControlAllowCredentials = "Access-Control-Allow-Credentials";

protected override async Task<HttpResponseMessage> SendAsync(HttpRequestMessage request, CancellationToken cancellationToken)
{
var isCorsRequest = request.Headers.Contains(Origin);
var isPreflightRequest = request.Method == HttpMethod.Options;
if (isCorsRequest)
{
if (isPreflightRequest)
{
var response = new HttpResponseMessage(HttpStatusCode.OK);
response.Headers.Add(AccessControlAllowOrigin, request.Headers.GetValues(Origin).First());

var accessControlRequestMethod = request.Headers.GetValues(AccessControlRequestMethod).FirstOrDefault();
if (accessControlRequestMethod != null)
{
response.Headers.Add(AccessControlAllowMethods, accessControlRequestMethod);
}

var requestedHeaders = string.Join(", ", request.Headers.GetValues(AccessControlRequestHeaders));
if (!string.IsNullOrEmpty(requestedHeaders))
{
response.Headers.Add(AccessControlAllowHeaders, requestedHeaders);
}
response.Headers.Add(AccessControlAllowCredentials, "true");

var tcs = new TaskCompletionSource<HttpResponseMessage>();
tcs.SetResult(response);
return response;
}

var resp = await base.SendAsync(request, cancellationToken);
resp.Headers.Add(AccessControlAllowOrigin, request.Headers.GetValues(Origin).First());
resp.Headers.Add(AccessControlAllowHeaders, "*");
resp.Headers.Add(AccessControlAllowCredentials, "true");
return resp;
}
return await base.SendAsync(request, cancellationToken);
}
}

在我的 WebApiConfig 类中,我正在注册该处理程序,如下所示:
config.MessageHandlers.Add(new CorsHandler());

它被称为“GET”请求。但它不会因任何需要飞行前批准的请求而被调用。请求如下所示:
Request OPTIONS /api/campaigns/1002/customerusers/1008 HTTP/1.1
Accept */*
Origin http://app.dev.alanta.com
Access-Control-Request-Method DELETE
Access-Control-Request-Headers accept
Accept-Encoding gzip, deflate
User-Agent Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.1; Trident/6.0)
Host dev.payboard.com
Content-Length 0
DNT 1
Connection Keep-Alive
Cache-Control no-cache

但正如我所说,处理程序永远不会被调用来使用 OPTIONS 动词。

我认为可能有其他一些处理程序在某处干扰了这个,但我已经删除了所有可能的候选人,到目前为止没有运气。

我的另一个理论是它没有识别 OPTIONS 动词的特定路由,因此它永远不会将请求交给 WebApi 子系统,而是在其他地方处理。但我不完全清楚如何解决这个问题。

建议?

最佳答案

将以下内容添加到 web.config:

<handlers>
<remove name="OPTIONSVerbHandler" />
</handlers>

关于asp.net-web-api - 未为预检 CORS 请求调用 WebApi DelegatingHandler,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18704669/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com