我使用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

最佳答案

看起来像Web服务本身中的问题。

服务可能会从其他服务获取数据本身并继续传递。如果其他服务在预定的时间范围内不接受来自客户端的重复连接(重试标头)。

关于ios - NSURLConnection和服务器响应出现问题,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/32522495/

10-16 20:06
查看更多