jQuery Ajax调用运行错误,但firebug显示200 ok并返回json

时间:2014-03-06 08:12:48

标签: jquery ajax json web-services

我已经阅读了很多关于ajax问题的帖子,但我仍然不知道什么可能导致我的问题:

我正在尝试通过ajax调用RESTful服务(内部)以获取大型json-String。

编辑:这就是我现在解决这个问题的方法 - 我知道这不是一个很好的解决方案,但由于我现在无法改变网络服务上的任何内容,这就是我使用的:

<!DOCTYPE html>
<html>
<head>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js">
</script>
<script>
jQuery(document).ready(function(){
    jQuery.support.cors = true;
    jQuery.ajax({
        url: "<internalPage>",
        dataType: 'json'
    })
    .error(function(xhr, err, status) {
        console.log(xhr + err + status);
    })
    .then(function(data) {
        alert("success for me");
        $.each(data.portalServices, function(index, value) {
            $("#someId").append('<li>' + value.name + '</li>');
        });
    });
});

</script>
</head>
<body>
<ul id="someId"></ul>
</body>
</html>

编辑:这仅适用于IE而非FF。

警报说: Ajax错误 类型:GET 请求页面: 状态:0 - 错误 错误抛出:

但是在Firebug:

Response-Header
Content-Type    application/json
Date    Thu, 06 Mar 2014 07:44:32 GMT
Server  Apache-Coyote/1.1
Transfer-Encoding   chunked
Anfrage-HeaderQuelltext anzeigen
Accept  application/json, text/javascript, */*; q=0.01
Accept-Encoding gzip, deflate
Accept-Language de-de,de;q=0.8,en-us;q=0.5,en;q=0.3
Cache-Control   no-cache
Connection  keep-alive
Host    xxxxxx
Origin  null
Pragma  no-cache
User-Agent  Mozilla/5.0 (Windows NT 6.1; WOW64; rv:27.0) Gecko/20100101 Firefox/27.0

Responce-Header from Cache
Content-Type    application/json
Date    Thu, 06 Mar 2014 07:44:32 GMT
Server  Apache-Coyote/1.1
Transfer-Encoding   chunked

状态为200 OK 响应是一个有效的Json(真的,我在线验证了它) {“portalServices”:[{“articleID”:“ABR_1043024010”,“name”:“SK04受管服务器:Citrix Basisservice”,“portalname”:“zentrale Arbeitsplatz-Umgebung(Citrix-Basis)”,“preis”:18.0000, “beschreibung”:“Mit diesem Produkt stellen wir Ihnen eine zentrale Arbeitsplatz-Umgebung(auf der Basis von Citrix)bereit,die folgende Komponenten ....

但是没有JSON标签。

当我使用缓存假时,Firebug不会向我显示响应,并且警报中显示的错误如下:

Ajax Error
Type:GET
Requesting Page: <internalPage>
Status: 0 - Exception ..."Failure" nsresult: "0x80004005 (NS_ERROR_FAILURE)" location "JS frame :: <link to jquery> :: .send :: line 6 " data: no .....

我还尝试了对另一个成功的服务(“http://rest-service.guides.spring.io/greeting”)的ajax调用。在firebug中有一个JSON选项卡,但这可能是因为从这个站点返回的json不是像我从内部站点webservice返回的json那样的对象列表。

有什么想法吗?我认为Web服务可能存在问题,但是如果你得到一些线索可能会有什么问题会很好。 非常感谢。

即使有以下情况,它仍然无效= /

headers: {'Access-Control-Allow-Origin': '<internalPage>'},
dataType: 'jsonp',
crossDomain: true

internalPage不在同一个域中,但不会响应来自外部网络的请求。对spring服务的调用确实有效,没有明确允许crossDomain或像上面那样设置标题。

我会按照parsererror after jQuery.ajax request with jsonp content type的建议尝试,然后回来告诉它是否有效。

编辑:将来会更改WebServices,以便我可以使用jsonp而不是强制jQuery来允许跨域Ajax调用。

编辑:WebService已经更改,所以现在它可以正常使用数据类型jsonp。 =)

感谢您的帮助。

2 个答案:

答案 0 :(得分:0)

您确定此请求导致错误吗? $(document).ajaxError是一个全局错误处理程序(在任何错误上调用),因此你可能有一个不同的ajax调用导致它

您可以将代码更改为:

 jQuery.ajax({
        url: "http://<internalPage",
        dataType: 'json'
    })
    .error(function(xhr, err, status) {
       console.log(xhr + err + status);
    })
    .then(function(data) {
       alert("success for me");
    });

尝试其他浏览器,即Chrome,可能是您有一些导致问题的扩展程序

您是否使用相同的网址,即不提出跨域请求? jQuery Call to WebService returns "No Transport" error

答案 1 :(得分:0)

我认为你的jquery Ajax代码有问题

试用此代码

$.ajax({
    url: "http://<internalPage",
    dataType: 'json',
    success:function(data){
       alert(data); 
       // beter to use eval instead of alert
    }

});