最近公司项目涉及多图上传到问题,简单的说一下解决思路。
项目图片是在保存到七牛服务器,但是七牛只支持单图上传,单图上传很简单就可以解决。多图上传:我的思路是使用for循环,尝试了一下成功了,问题貌似解决了,可接下来的问题又来了,图片的上传循序和自己想的完全不一样。解决这个问题,首先想到的是用线程同步来解决这个问题,那么问题又来了,这样效率不能得到保证,果断放弃。回头又给七牛官方文档详细的啃了一遍,虽然七牛没有提供多图上传的api,但是,官方给了这样一段话:
屏幕快照 2017-12-04 下午7.18.54.png
QNUploadOption *opt = [[QNUploadOption alloc] initWithMime:@"text/plain" progressHandler:nil params:@{ @"x:foo":@"fooval" } checkCrc:YES cancellationSignal:nil];
[upManager putData:data key:@"hello" token:token
complete: ^(QNResponseInfo *info, NSString *key, NSDictionary *resp) {
NSLog(@"%@", info);
NSLog(@"%@", resp);
} option:opt];
看了这段话顿时醒悟,随即在七牛又封装了一个这样的方法:
-(void)toUpLoadFiles:(NSData*)data withIndex:(NSString *) index
successBlock:(qiNiuSuccessBlock)successBlock
failBlock:(qiNiufailBlock)failBlock {
NSDate* dat = [NSDate dateWithTimeIntervalSinceNow:0];
NSTimeInterval a=[dat timeIntervalSince1970]*1000;
NSString *timeString = [NSString stringWithFormat:@"%.0f", a];
QNUploadOption *opt = [[QNUploadOption alloc] initWithMime:@"text/plain" progressHandler:nil params:@{ @"x:index":index } checkCrc:YES cancellationSignal:nil];
__weak typeof(self) weakSelf = self;
[self.upManager putData:data key:[NSString stringWithFormat:@"img_%@",timeString] token:self.token
complete: ^(QNResponseInfo *info, NSString *key, NSDictionary *resp) {
if (info.statusCode==401) {
//token过期
weakSelf.token = nil;
[weakSelf getQiNiuToken:data successBlock:successBlock failBlock:failBlock];
return;
}
successBlock(info,key,resp,weakSelf.url);
} option:opt];
}
在原来上传单张图片的方法里面添加一个参数:index(图片上传的顺序),再使用for循环上传图片,index即是传入的for循环的循环变量,这样既解决了多图上传的问题,同时又解决了上传效率问题。
需要注意的是:图片上传是异步上传的图片的顺序现在还是混乱的,我们已经对上传的图片使用index进行了标注,需要我们将上传的图片存到一个数组中按照index进行再次排序,上代码:
屏幕快照 2017-12-04 下午7.33.31.png
持续更新~
网友评论