网络错误405:从浏览器发布到Localhost WCF REST Web服务

时间:2013-10-13 07:19:25

标签: .net json wcf

我正在编写一个使用dotnet rest Web服务的网站。我完全控制了这两个项目。

就在今天,我实施了一项帖子后服务。当我用Fiddler发帖时,它有效。今天早上我从网站上运行了一些测试,一切似乎都没问题。我处理了另一个问题(用fiddler获取帖子内容)我回到浏览器发布但现在整个网站都展示了CORS行为 - 空白返回等等。此外,刚刚实现的帖子刚开始返回405方法不允许错误

"NetworkError: 405 Method Not Allowed - http://localhost:50122/MyService/ListMarkers"

以下是网站代码:

 function postAjax(){
    var markers = 
    { "listmarkers":
    [{ "position": "128.3657142857143", "markerPosition": "7" },
                   { "position": "235.1944023323615", "markerPosition": "19" },
                   { "position": "42.5978231292517", "markerPosition": "-3" }]
    };

    $.ajax({
        type: "POST",
        url: window.url + "/PocShimService.svc/ListMarkers",
        // The key needs to match your method's input parameter (case-sensitive).
        data: JSON.stringify(markers),
        //data: markers,
        contentType: "application/json; charset=utf-8",
        dataType: "json",
        success: function(data){alert(data);},
        failure: function(errMsg) {
            alert(errMsg);
        }
    });

}

以下是与访问控制有关的服务器配置:

<httpProtocol>
  <customHeaders>
    <add name="Access-Control-Allow-Origin" value="*" />
    <add name="Access-Control-Allow-Headers" value="Content-Type" />
  </customHeaders>
</httpProtocol>

有什么想法吗?建议?

1 个答案:

答案 0 :(得分:1)

如果您的域名与WCF和客户端应用相同,那么您必须尝试 window.location.origin 而不是 window.url 。你的ajax请求应该是

$.ajax({
    type: "POST",
    url: window.location.origin + "/PocShimService.svc/ListMarkers",
    // The key needs to match your method's input parameter (case-sensitive).
    data: JSON.stringify(markers),
    //data: markers,
    contentType: "application/json; charset=utf-8",
    dataType: "json",
    success: function(data){alert(data);},
    failure: function(errMsg) {
        alert(errMsg);
    }
});