他のドメインの Web API に PUT および DELETE CORS リクエストを実行するときに問題があります。
チュートリアルに従ってAPIをコーディングしましたhttp://www.asp.net/web-api/overview/security/enable-cross-origin-requests-in-web-api#create-webapi-project を参照してください。。
GET および POST リクエストは正常に動作しますが、DELETE および PUT は動作しません。次のメッセージが表示されます:
Failed to load resource: the server responded with a status of 405 (Method Not Allowed)
Failed to load resource: No 'Access-Control-Allow-Origin' header is present on the requested resource.
WebConfigにコードを追加すると、ASP.NET Web API による PUT および DELETE の CORS サポート最初のエラーのみが発生します。
誰かこれを手伝ってくれませんか?
ベストアンサー1
このタイプのリクエストを処理するためのハンドラーを追加できます。
「DelegatingHandler」から派生したクラスを作成します。
public class PreflightRequestsHandler : DelegatingHandler
{
protected override Task<HttpResponseMessage> SendAsync(HttpRequestMessage request, CancellationToken cancellationToken)
{
if (request.Headers.Contains("Origin") && request.Method.Method.Equals("OPTIONS"))
{
var response = new HttpResponseMessage { StatusCode = HttpStatusCode.OK };
// Define and add values to variables: origins, headers, methods (can be global)
response.Headers.Add("Access-Control-Allow-Origin", origins);
response.Headers.Add("Access-Control-Allow-Headers", headers);
response.Headers.Add("Access-Control-Allow-Methods", methods);
var tsc = new TaskCompletionSource<HttpResponseMessage>();
tsc.SetResult(response);
return tsc.Task;
}
return base.SendAsync(request, cancellationToken);
}
}
後で、WebApiconfig.cs の Register メソッドに以下を追加します。
public static void Register(HttpConfiguration config)
{
// Define and add values to variables: origins, headers, methods (can be global)
// Enable global CORS
config.EnableCors(new EnableCorsAttribute(origins, headers, methods));
// Add handler to deal with preflight requests, this is the important part
config.MessageHandlers.Add(new PreflightRequestsHandler()); // Defined above
.
.
.
}