还请检查我在底部的更新
我在Chrome中执行跨域jQuery.ajax GET REQUEST时遇到一些问题。
预战非常长(最多20秒),而在Firefox中运行良好。
我尝试了不同的提示(例如启用异步),但我无法管理。响应是一个json对象数组,并不是很大(只有几个字节)。
问题似乎只在第一次通话时出现。我做了一个再次执行请求的函数。它由成功处理程序执行。从最小12秒开始第一次延迟后,请求执行正常。
我已经尝试过不同版本的jQuery(因为我是第一次使用2.0.3)。
我登录了服务器。正如想象的那样,OPTION请求最多不会执行20秒。没有服务器问题。服务器完全根据延迟识别命令并执行GET方法。
对于页面加载2014-01-11 14:59:00我的日志输出如下:
2014-01-11 14:59:14 - log.txt - "OPTIONS /unit/IO/*?_=1389452340572 HTTP/1.1" 200 -
2014-01-11 14:59:14 - log.txt - "GET /unit/IO/*?_=1389452340572 HTTP/1.1" 200 -
2014-01-11 14:59:14 - log.txt - "OPTIONS /unit/IO/*?_=1389452340573 HTTP/1.1" 200 -
2014-01-11 14:59:14 - log.txt - "GET /unit/IO/*?_=1389452340573 HTTP/1.1" 200 -
这是我的ajax电话:
$.ajax({
url: <<crossdomain>>,
type: 'GET',
contentType:'application/json',
async:true,
cache:false,
beforeSend: function (request)
{
request.setRequestHeader("Authorization", 'Basic ' + encodedData);
},
success: function(response) {
alert(response)
}
});
请求标头(Chrome):
Accept:*/*
Accept-Encoding:gzip,deflate,sdch
Accept-Language:de-DE,de;q=0.8,en-US;q=0.6,en;q=0.4
Access-Control-Request-Headers:accept, authorization, content-type
Access-Control-Request-Method:GET
Cache-Control:max-age=0
Connection:keep-alive
DNT:1
Host:<<crossdomain>>
Origin:<<thisdomain>>
Referer:<<directpathonthisdomain>>
User-Agent:Mozilla/5.0 (Macintosh; Intel Mac OS X 10_8_5) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/31.0.1650.63 Safari/537.36
回复标题(Chrome):
Access-Control-Allow-Headers:Authorization
Access-Control-Allow-Headers:Accept
Access-Control-Allow-Headers:Content-Type
Access-Control-Allow-Headers:Accept-Language
Access-Control-Allow-Methods:POST, GET, OPTIONS
Access-Control-Allow-Origin:*
Cache-Control:no-cache
Content-Type:application/json
Date:Sat, 11 Jan 2014 13:28:32 GMT
Server:Python3.2
这是第一次通话的网络流量:
铬:
OPTION 的
DNS Lookup: 0 ms
Connecting: 3 ms
**Waiting: 17.44s**
Receiving 2 ms
GET
DNS Lookup: 0 ms
Connecting: 2 ms
Sending: 0 ms
Waiting: 46 ms
Receiving 1 ms
用于比较Firefox日志:
OPTION 的
DNS Lookup: 0 ms
Waiting: 10 ms
Receiving 5 ms
GET
DNS Lookup: 0 ms
Waiting: 41 ms
Receiving 3 ms
修改 如果我直接打开html文件(file:///)而不是托管在本地/远程服务器上,则没有问题。
编辑2: 它适用于Chrome隐身模式 - 可能是缓存问题吗?
答案 0 :(得分:6)
我遇到了同样的问题。禁用选项&#34;预测网络操作以提高页面加载性能后#34;在Chrome的高级设置中,延迟消失了。
答案 1 :(得分:0)
也许您可以将下一个标头添加到您的ajax请求中。
headers: {
"Cache-Control" : "no-cache, no-store, must-revalidate",
"Pragma": "no-cache",
"Expires", "0"
}