我已经阅读了很多关于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。 =)
感谢您的帮助。
答案 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
}
});