iOS断点断不到_数据


#import "MainViewController.h"

@interface MainViewController ()

@end

@implementation MainViewController

- (void)viewDidLoad
{
    [super viewDidLoad];
    //下载文件
    [self download];
}

-(void)download
{
    //1. NSURL
    NSURL *url = [NSURL URLWithString:@"http://loacal/~apple/itcase/download/iTunesConnect_DeveloperGuide_CN.zip"];
    //2NSRequest
    //要推断网络server上文件的大小。能够使用Http的HEAD方法
    NSMutableURLRequest *request = [NSMutableURLRequest requestWithURL:url];
    
    
    //使用HEAD方法。仅获取目标文件的信息,而不做实际的下载工作。

//[request setHTTPMethod:@"HEAD"]; /** 设置断点续传的思路: HeaderField:头域(请求头部的字段) 能够通过指定range的范围逐步地下载指定范围内的数据,待下载完毕后,再将这些数据拼接成一个文件。

1依据HEAD方法获取到要下载的文件的总大小、 2在磁盘上建立一个暂时的缓冲文件。该文件的大小与目标文件大小一致 3缓冲文件里全部字节都是默觉得0 4开启多线程。分别载入不同的range头指定的数据块。待数据块载入完毕以后,将其分别写入相应的偏移地址。 5全部数据下载完毕以后。表示文件下载完毕。将暂时文件名称更改为目标文件。 开发的难点: 0 在写入文件之前,首先要建立一个同等大小的文件。 1 文件的读写问题,在oc里默认是覆盖,追加,假设要指定位置,须要用seek方法,移动文件指针。 2在多线程写入文件时。文件的锁定操作是一个问题。 */ [request setValue:@"bytes=0-499" forKeyPath:@"range"];//表示仅仅读取数据的第0个字节到第499个字节。 //3NSURLConnection //假设要获取文件长度。能够在Response中获取到 NSURLResponse *response = nil; NSData *data = [NSURLConnection sendSynchronousRequest:request returningResponse:&response error:nil]; //在response的expectedcontentlength属性中,能够获知要卸载的文件的文件长度。 NSLog(@"%lld %d%@", [response expectedContentLength], data.length, data); } @end