我有下面的jQuery调用一个WCF方法。方法调用成功的程度,我可以看到它记录,它返回一个布尔值true。但是,错误处理程序返回"AJAX调用在CallIsDataReady中失败"one_answers"语法错误:无效字符"。然后,它不采用成功路径调用callUpdateGrid。我找不到无效字符。的帮助!
function CallIsDataReady(input) {
$.ajax({
url: "http://www.blah.com/services/TestsService.svc/IsDataReady",
type: "GET",
contentType: "application/json; charset=utf-8",
data: input,
dataType: "json",
success: function (data) {
if (!data) {
setTimeout(function (inputInner) { CallIsDataReady(inputInner); }, 1000);
}
else {
console.log("data returned - calling callUpDateGrid");
//Continue as data is ready
callUpdateGrid(input);
}
},
error: function (jqXHR, textStatus, errThrown) {
console.log("AJAX call failed in CallIsDataReady");
console.log(errThrown);
}
});
}
$(document).ready(function () {
var input = { "requestGUID": "<%=guid %>" };
CallIsDataReady(input);
});
服务器端方法返回JSON,因为它是一个启用AJAX的Web服务:
[OperationContract]
[WebGet]
public bool IsDataReady(string requestGUID)
{
bool isReady = Global.publicDataDictionary.Keys.Contains(requestGUID);
using (savitasEntities2 db = new savitasEntities2())
{
DataRequestLog drl = new DataRequestLog();
drl.registrationID = "";
drl.request = "Is Ready=" + isReady;
drl.connectionID = "";
drl.created = System.DateTime.Now.ToUniversalTime();
drl.direction = "tickler";
drl.dataRequestGUID = requestGUID;
db.DataRequestLogs.Add(drl);
db.SaveChanges();
}
return isReady;
}
编辑:第二个JavaScript方法是:
function callUpdateGrid(input) {
console.log(input);
$.ajax({
url: "http://www.blah.com/services/TestsService.svc/GetContactsDataAndCountbyGUID",
type: "GET",
contentType: "application/json; charset=utf-8",
data: input,
dataType: "json",
success: function (data) {
var mtv = $find("<%= RadGrid1.ClientID %>").get_masterTableView();
console.log(data);
mtv.set_dataSource(data.d.Data);
mtv.dataBind();
},
error: function (jqXHR, textStatus, errThrown) {
console.log("AJAX call failed in callUpdateGrid");
console.log(errThrown);
}
});
}
当您的代码工作时,您仍然应该考虑这些事情。我不是JavaScript专家,但我相信你调用方法的方式是不正确的。首先,你的OperationContract
是WebGet
,所以你的请求中不需要提供Content-Type
。Content-Type
通常在您使用POST方法发送大量数据时使用。因此,根据我的说法,修改如下:
[OperationContract]
[WebGet(UriTemplate = "/GUID={requestGUID}", ResponseFormat = WebMessageFormat.Json)]
public bool IsDataReady(string requestGUID)
{
bool isReady = Global.publicDataDictionary.Keys.Contains(requestGUID);
using (savitasEntities2 db = new savitasEntities2())
{
DataRequestLog drl = new DataRequestLog();
drl.registrationID = "";
drl.request = "Is Ready=" + isReady;
drl.connectionID = "";
drl.created = System.DateTime.Now.ToUniversalTime();
drl.direction = "tickler";
drl.dataRequestGUID = requestGUID;
db.DataRequestLogs.Add(drl);
db.SaveChanges();
}
return isReady;
}
我希望这一定会起作用。现在这个方法将返回JSON格式的isReady
。如果您没有在OperationContract
中指定ResponseFormat
,那么默认情况下它将返回到XML
。
现在尝试删除Content-Type: application/json; charset=utf-8
,因为您没有在JSON中发送数据并执行您的方法。响应将是JSON格式,因此,您必须解析它以获得isReady
值。
使用此URL调用service:
url: "http://www.blah.com/services/TestsService.svc/GUID=abc123"
这很简单,很容易实现。谢谢您的耐心等待。
编辑:添加BodyStyle = WebMessageBodyStyle.Bare
OperatcionContract
。