我正在编写一个使用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>
有什么想法吗?建议?
答案 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);
}
});