zoukankan      html  css  js  c++  java
  • iOS连续上传多张图片

    参考地址:http://www.cocoachina.com/ios/20180730/24366.html

    需求是怎样的:for 循环里面、多个网络请求上传图片,每次上传一张,至于为什么每次只上传一张呢,因为上传一张将要返回图片存储服务器的地址,然后再把地址作为请求参数,请求自己服务器的 API。

    过程可以说曲折,不过也有收获

    解决方案一:

    递归调用上传图片的函数、第一张请求成功后,然后第二张,依次进行。当然效率肯定不高,即使上传图片的AFN方法做了多线程处理。中间上传失败了,还继续上传吗?需求决定。所有放弃

    解决方案二:

    使用GCD 队列组:这里就直接贴代码了:

    dispatch_group_t group =  dispatch_group_create();
       for(..){
            dispatch_group_async(group,dispatch_get_global_queue(0, 0), ^{
            NSLog(@"队列组:有一个耗时操作完成!");
            });
          }
    
        dispatch_group_notify(group, dispatch_get_main_queue(), ^{
            NSLog(@"队列组:前面的耗时操作都完成了,回到主线程进行相关操作");
        });
    
     

    我只能说想法很完美啊,网上也不只提出这种方案,但是我的实践过程是有问题了。网络请求延迟,队列组不可控。所以放弃

    方案三:利用数组的有序性:

    怎么个利用法?请看:

    1. 创建一个模型、两个属性第一个你要上传的数据信息如:image 或者 data ,根据你上传函数需要的参数来定。第二个属性:NSString URL 服务端返回的图片地址:

    2. 将你要上传的图片数组、封装成模型数组,数组是有序的这就是重点,for 循环 模型作为参数调用图片上传函数,请求成功后更新模型的值

    3. 判断所有的图片上传完毕,然后,就从模型数组里面去取 ,图片 url ,请求自己的服务器api

    好了,应该很清楚吧。不清楚再上点干货:

    model:

    // 建立这个类的目的、主要是为了for循环多张图片上传、成功后回来的地址顺序问题

    #import 

    @interface FMUploadModel : NSObject
    //根据自己的上传函数需要决定
    @property (nonatomic,strong) NSArray * dataArray;

    @property (nonatomic,copy) NSString *imgUrl;

    @end

    function

    //开辟一个多线程 执行图片上传工作
              
     dispatch_queue_t queue = dispatch_queue_create("upimgs", DISPATCH_QUEUE_CONCURRENT);
    
                dispatch_async(queue, ^{
                    // 耗时操作放在这里
    
                    __weak typeof(self) weakself = self;
                    __block int finishNum = 0;
                    for (int i = 0 ; i < self.selectImgs.count; i++) {
                        YRFormData *getData = [[YRFormData alloc] init];
                        getData.data = UIImagePNGRepresentation(self.selectImgs[i]);
                        getData.name = @"uzee_image";
                        getData.filename = @"head.png";
                        getData.mimeType = @"image/png";
                        NSArray *array = @[getData];
                        //***********//
                        FMUploadModel *model = [FMUploadModel new];
                        model.dataArray = array;
                        model.imgUrl = @"";
                        [models addObject:model];
                        /*******其实是一张一张传的,传数组是调用这个方法**********/
                        [YRHttpTool postWithURLNoAES:@"*****" params:@{} formDataArray:model.dataArray success:^(id json) {
                            finishNum ++ ;
                            model.imgUrl = json[@"response"][@"cloud"];
                            if (finishNum == self.selectImgs.count) {
                                dispatch_async(dispatch_get_main_queue(), ^{
                                    // 回到主线程进行UI操作
                                    [MBProgressHUD hideHUDForView:weakself.view];
                                    updateImage();
                                });
    
                            }
    
                        } failure:^(NSError *error) {
                            dispatch_async(dispatch_get_main_queue(), ^{
                                // 回到主线程进行UI操作
                                [MBProgressHUD hideHUDForView:weakself.view];
                                [MBProgressHUD showError:@"图片上传失败,请稍后再试" toView:self.view];
                            });
                        } progress:^(NSProgress *progress) {
                            [[NSOperationQueue mainQueue] addOperationWithBlock:^{
    
                                float value = 1.0 *progress.completedUnitCount / progress.totalUnitCount;
                                [MBProgressHUD showDownload:@"发布中..." toView:weakself.view progress:value];
                            }];
    
                        }];
    
    
                    }
                });
    
  • 相关阅读:
    composer在phpstorm中安装代码库
    [C#]WinForm 中 comboBox控件之数据绑定
    【建模+强连通分量】POJ1904 King's Quest
    【构造】UVa 11387 The 3-Regular Graph
    【环套树+树形dp】Bzoj1040 [ZJOI2008] 骑士
    【强连通分量+spfa】Bzoj1179 Apio2009 Atm
    【树形dp】Bzoj3391 [Usaco2004 Dec]Tree Cutting网络破坏
    【dfs+连通分量】Bzoj1123 POI2008 BLO
    【强连通分量+概率】Bzoj2438 杀人游戏
    【强连通分量】Bzoj1194 HNOI2006 潘多拉的盒子
  • 原文地址:https://www.cnblogs.com/hualuoshuijia/p/9448546.html
Copyright © 2011-2022 走看看