调用wcf Web服务使用jquery-Ajax失败,请求失败,却不知道确切的问题。 它甚至都没有称任何方法成功或失败。 使用iis将Web服务和网站都部署在同一服务器上
错误:
Failed to load resource: the server responded with a status of 400 (Bad Request)
该代码用于调用服务方法:
function test(){
try {
code = getValuesWrittenInTheURL[0] + "";
var query = "select taskstatus,tasksubstatus,Lat,Lng,elementID from tasks_gvt where code = '" + code + "'";
$.ajax({
type: "POST",
async: true,
url: IP + "/GetData",
data: JSON.stringify({ Query: query }),
dataType: "json",
success: function (data) {
debugger;
console.log("data: ",data);
},
failure: function (errMsg) {
debugger;
console.log("err",errMsg);
}
});
} catch (error) {
console.log("alaaError", error.message);
}
}
WCF Web服务运营合同:
[WebInvoke(Method = "POST", RequestFormat = WebMessageFormat.Json, UriTemplate = "GetData", BodyStyle = WebMessageBodyStyle.WrappedRequest)]
Response GetData(String Query);
准备为您提供更多详细信息。
答案 0 :(得分:1)
下面是我成功访问该服务的Ajax,您可以参考它:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Ajax</title>
<script src="https://cdn.staticfile.org/jquery/1.10.2/jquery.min.js">
</script>
<script>
$(document).ready(function(){
$("button").click(function () {
code = "code";
var query = "select taskstatus,tasksubstatus,Lat,Lng,elementID from tasks_gvt where code = '" + code + "'";
da={"Query":query}
$.ajax({
type: "Post",
dataType: "json",
contentType: "application/json;charset=utf-8",
data: JSON.stringify(da),
url: "http://localhost/Service1.svc/GetData", success: function (result) {
}});
});
});
</script>
</head>
<body>
<button>Call WCF Rest Service</button>
</body>
</html>
您需要设置contentType,我看到您将BodyStyle设置为Wrapped,如果将其设置为Wrapped,则请求格式应如下所示:
{"Query":query}