2012-06-19 100 views
0

我正在jQuery中运行此getJSON异步调用,以便将数据返回到Java代码中,然后从中移出。无论出于何种原因,我不断得到错误:运行jQuery getJSON时发生Ajax错误

"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 + ')'); 
       } 
      }); 
} 
+3

[Stack Overflow是不是一个调试服务] (http://meta.stackexchange.com/a/135066/173320)您应该尝试调试代码,找到问题的位置,然后提出具体问题。 – gdoron

+1

难道可能是因为你有'getJSON'而不是'$ .getJSON'? –

+1

getJson是什么? – jbabey

回答

1

看来,从服务器响应的内容不是JSON格式。因为您将$ .ajax的响应类型指定为json,所以您需要将对象结果转换为json。您可以使用谷歌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; 
+0

这工作的第一次,但第二次我试着运行它的控制台输出'JSON为空'在'如果(json.successful)' – PseudoPsyche

+0

啊,没关系!我重新启动了我的JBoss服务器,它一切正常!谢谢!这也很方便,因为我已经在这个应用程序的其他地方使用Gson,所以这些库已经在那里。 – PseudoPsyche

+0

我找不到解释它的原因。但显然你应该在服务器上返回一个json格式的字符串,如果你使用这样的javascript。 – guanxiaohua2k6

0

响应不缝合是有效的!

我检查了它,你有一个无效的标签有Ljava.lang.String; @ 1e40c9f,解析您的代码时,我得到的错误是:

SyntaxError: invalid label