JQuery Ajax POST 到 Web API 返回 405 方法不允许

标签 jquery ajax cors asp.net-web-api

所以我有一个像这样的 jquery ajax 请求:

    function createLokiAccount(someurl) {
    var d = {"Jurisdiction":17}

        $.ajax({
                type: "POST",
                url:"http://myserver:111/Api/V1/Customers/CreateCustomer/",
                data: JSON.stringify(d),
                contentType: "application/json; charset=utf-8",
                dataType: "json",
                success: function(data){alert(data);},
                failure: function(errMsg) {
                    alert(errMsg);
                }
            });
    }

这正在访问我的网络 API,基本上是:

    [HttpPost]
    public CreateCustomer.Response CreateCustomer(CreateCustomer.Request request)
    {
        HttpContext.Current.Response.AppendHeader("Access-Control-Allow-Origin", "*");
    ...

当我在 Chrome 中调用它时,会得到:

OPTIONS http://myserver:111/Api/V1/Customers/CreateCustomer/ 405 (Method Not Allowed) 
No 'Access-Control-Allow-Origin' header is present on the requested resource.      

当我从 Fiddler 发出 POST 请求时,它应该在响应 header 中包含“Access-Control-Allow-Origin: *”,这表明 API 配置正确,但(来自 Fiddler)jquery 请求看起来像:

选项http://myserver:111/Api/V1/Customers/CreateCustomer/ HTTP/1.1 主机:我的服务器:111 连接:保持事件状态 访问控制请求方法:POST 来源:http://localhost:6500 用户代理:Mozilla/5.0(Windows NT 6.1;WOW64)AppleWebKit/537.36(KHTML,如 Gecko)Chrome/34.0.1847.116 Safari/537.36 访问控制请求 header :接受,内容类型 接受:/ 推荐人:http://localhost:6500/Home/Replication?interval=1 接受编码:gzip、deflate、sdch 接受语言:en-US,en;q=0.8,en-GB;q=0.6,it-IT;q=0.4,it;q=0.2

那么为什么我的 POST 请求变成了 OPTIONS 请求?

最佳答案

首先,您只添加一个 header ,但您至少需要三个 header :

"Access-Control-Allow-Origin", "*"

"Access-Control-Allow-Methods", "GET, POST, PUT, DELETE"

"Access-Control-Allow-Headers", "Content-Type, Accept"

其次,如果您仅需要某个 Controller 中的一种方法使用 CORS,那么添加 header 的方式就可以。但总的来说这是不对的。

带有 Web API 2 的 ASP.NET 5 提供 CORS library .

但是如果您使用 Web API,我可以提供解决方案(不是真正正确,但有效)。只需添加(在 Global.asax 中)到每个请求所需的 header

protected void Application_BeginRequest(object sender, EventArgs e)
{
    HttpContext.Current.Response.AddHeader("Access-Control-Allow-Origin", "*");
    if (HttpContext.Current.Request.HttpMethod == "OPTIONS")
    {
        HttpContext.Current.Response.AddHeader("Access-Control-Allow-Methods", "GET, POST, PUT, DELETE");
        HttpContext.Current.Response.AddHeader("Access-Control-Allow-Headers", "Content-Type, Accept");
        HttpContext.Current.Response.AddHeader("Access-Control-Max-Age", "1728000");
        HttpContext.Current.Response.End();
    }

}

关于JQuery Ajax POST 到 Web API 返回 405 方法不允许,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29813719/

相关文章:

javascript - Backbone.js - 将数据保存到服务器

spring - 允许 OPTIONS HTTP 方法用于 oauth/token 请求

javascript - Jquery 根据浏览器大小/调整大小更改高度

javascript - 重新填充 Canvas 删除区域的区域

javascript - 使用 jquery 将 mysql 数据获取到新表行

javascript - AJAX 调用和更新查询无法正常运行

java - 如何在JAVA中创建自己的代理服务器来解决CORS问题?

google-cloud-platform - Google Cloud Functions 启用 CORS 吗?

javascript - 为什么 jQuery 代码片段在没有 IFrame 的情况下可以工作,但在有 IFrame 的情况下却不能?

javascript - anchor 不起作用