我在jQuery中运行这个getJSON异步调用,以便将数据恢复到我的Java代码之后。无论出于何种原因,我不断得到错误:
"Ajax Error: Error invoking generateSearchQuery([object Object])"
我调试了jQuery和Java代码。 Java代码接收JSON数据,对其进行处理,并将其写回而不会出现问题。当jQuery代码进入内部getJson方法并尝试if(json.successful)
时,它会触发错误。
回复是:{"error":{"message":"","title":"Error Generating Search Query"},"data":[Ljava.lang.String;@1e40c9f,"successful":"successful"}
我几天来一直在处理这个异步调用,但仍然无法正常工作。有什么想法吗?
jQuery函数:
generate : function(){
getJson(
Search.guid,
"generateSearchQuery",
{
"data": [
"val0",
"val1",
"val2",
"val3",
"val4"
]
}, function(json) {
Search.data = $.parseJSON(json.data);
$.each(Search.data, function(k, v){
$('#searchQuery').append(v + "\n");
});
});
},
Java函数:
@AsyncService(name = "generateSearchQuery", permission = "")
public void generateSearchQuery(HttpServletRequest req, HttpServletResponse res) {
res.setHeader("Cache-Control", "no-cache");
JSONResult result = new JSONResult("Error Generating Search Query");
String[] arr = req.getParameterValues("data[]");
for(int i = 0; i< arr.length; i++){
arr[i] = "success"+i+"!";
}
result.put("data", arr);
try {
res.getWriter().print(result);
} catch (IOException e) {
// whatever
}
}
}
的getJSON:
function getJson(guid, service, parms, callback) {
beginWork();
$
.ajax( {
url : document.URL,
type : 'GET',
data : parms,
cache : 'false',
dataType : 'json',
headers : {
'framework-guid' : guid,
'async-service' : service
},
success : function(json) {
endWork();
if (json.successful) {
callback(json);
} else {
error(json.error && json.error.title ? json.error.title
: 'No Title Provided', json.error
&& json.error.message ? json.error.message
: 'No message provided for service ' + service);
}
},
error : function(jqXHR, textStatus, errorThrown) {
endWork();
error('Ajax Error', 'Error invoking ' + service + '('
+ parms + ')');
}
});
}
答案 0 :(得分:1)
似乎来自服务器的响应内容不是json格式。因为您将$ .ajax的响应类型指定为json,所以您需要将对象结果转换为json。您可以使用google gson http://code.google.com/p/google-gson/,并执行以下操作。
Gson gson = new Gson();
res.getWriter().print(gson.toJson(result));
在getJson中,您应该进行以下更改。
//before
Search.data = $.parseJSON(json.data);
//after
Search.data = json.data;
答案 1 :(得分:0)
响应不接缝有效!
我查了一下,你有一个无效的标签 Ljava.lang.String; @ 1e40c9f ,我在解析你的代码时得到的错误是:
SyntaxError: invalid label