NSURLConnection和服务器响应问题

时间:2015-09-11 11:34:10

标签: ios nsurlconnection charles-proxy server-response

我使用NSURLConnection下载文件。(基本上我使用JGDownload Accelerator

我的问题是当我尝试在一个特定服务器上下载文件时,服务器提供的响应会有所不同,并给出了不同的标题响应,如下所示

Printing description of headers:
{
    "Accept-Ranges" = bytes;
    "Cache-Control" = "max-age=687749";
    Connection = "keep-alive";
    "Content-Length" = 35617808;
    "Content-Type" = "video/mp4";
    Date = "Fri, 11 Sep 2015 07:21:59 GMT";
    Etag = "\"ee90ce32a16fc115d0799d686e5fe1b4\"";
    Expires = "Sat, 19 Sep 2015 06:24:28 GMT";
    "Keep-Alive" = "timeout=20";
    "Last-Modified" = "Wed, 09 Sep 2015 13:41:37 GMT";
    Server = ucdn;
    "X-Timestamp" = "1441806096.99264";
    "X-Ureq-ID" = "PYMqMNZBGw7LI3xeAHCTQwJs2FvO0y0xuG3+g5B0KcBzTv1v4kTfwCzHQYgrBEGSJQ0tBMG5L+srffrjBfio1R1ChR+wABEHY92PCg==";
    "X-VHostId" = "10000, 200000";
}

{
    "Cache-Control" = "max-age=687430";
    Connection = "keep-alive";
    "Content-Length" = 1;
    "Content-Range" = "bytes 0-0/35617808";
    "Content-Type" = "video/mp4";
    Date = "Fri, 11 Sep 2015 07:27:18 GMT";
    Etag = "\"ee90ce32a16fc115d0799d686e5fe1b4\"";
    Expires = "Sat, 19 Sep 2015 06:24:28 GMT";
    "Keep-Alive" = "timeout=20";
    "Last-Modified" = "Wed, 09 Sep 2015 13:41:37 GMT";
    Server = ucdn;
    "X-Timestamp" = "1441806096.99264";
    "X-Ureq-ID" = "PYMqMNZBGw7LI3xeAHCTQwJs2FvO0y0xuG3+g5B0KcBzTv1v4kTfwCzHQYgrBEGSJQ0tBMG5L+srffrjBfio1R1ChR+wABEHY92PCg==";
    "X-VHostId" = "10000, 710000";
}

基本参与是content-length密钥,因为在第一个密钥中它提供了适当的值,在第二个密钥中它是错误的,并且我在那里延迟了大约30到40秒。

有什么方法可以避免这种延迟吗? 或者任何快速响应的解决方法我的意思是服务器在1到2秒内提供数据,但回调方法提供的数据迟到

请求/响应时间我使用Charles应用程序。 我发现的结果是HERE

2 个答案:

答案 0 :(得分:0)

看起来像是Web服务本身的一个问题。

服务有可能从不同的服务获取数据并传递它们。如果其他服务在预定义的时间内没有接受来自客户端的重复连接(Retry-After Header)。

答案 1 :(得分:0)

我已经尝试了所有可能的方法来减少时间延迟,但似乎没有办法使用NSURLConnection。所以我们已经请求Apple工程师支持这个问题,并会在一段时间内得到他们的一些回复。

直到那时,由于来自服务器的错误标题信息,没有其他方法可以避免这种延迟。

如果我收到Apple的任何回复,我会在这里更新。