浏览代码

1.文件上传部分逻辑处理---未完成

huangxiaodong 10 月之前
父节点
当前提交
ce1e172a21
共有 18 个文件被更改,包括 344 次插入25 次删除
  1. 1 0
      创维盒子/双子星云手机/Class/Set/MySetViewController.h
  2. 2 2
      创维盒子/双子星云手机/Class/Set/MySetViewController.m
  3. 1 1
      创维盒子/双子星云手机/Class/Set/previewFile/backupsOptionViewController.m
  4. 1 1
      创维盒子/双子星云手机/Class/Set/previewFile/previewAudioOrDocumentViewController.m
  5. 1 1
      创维盒子/双子星云手机/Class/Set/previewFile/previewFileAndFolderSecondViewController.m
  6. 1 1
      创维盒子/双子星云手机/Class/Set/previewFile/previewFileAndFolderViewController.m
  7. 1 1
      创维盒子/双子星云手机/Class/Set/previewFile/previewImageOrVideoViewController.m
  8. 1 1
      创维盒子/双子星云手机/Class/Set/previewFile/view/previewToUploadFileView.h
  9. 1 1
      创维盒子/双子星云手机/Class/Set/previewFile/view/previewToUploadFileView.m
  10. 26 0
      创维盒子/双子星云手机/Class/Set/uploadFile/model/uploadFileDataModel.m
  11. 1 0
      创维盒子/双子星云手机/Class/Set/uploadFile/uploadFileView/uploadFileRecordTableView.h
  12. 1 1
      创维盒子/双子星云手机/Class/Set/uploadFile/uploadFileView/uploadFileRecordTableView.m
  13. 1 1
      创维盒子/双子星云手机/NAS/NASViewController.m
  14. 1 1
      创维盒子/双子星云手机/NAS/NasPreviewVideoViewController.m
  15. 1 1
      创维盒子/双子星云手机/NAS/nasDownloadManager/nasDownloadFileManager.m
  16. 7 0
      创维盒子/双子星云手机/NAS/nasUploadManager/nasUploadFileManager.h
  17. 231 10
      创维盒子/双子星云手机/NAS/nasUploadManager/nasUploadFileManager.m
  18. 65 2
      创维盒子/双子星云手机/NAS/nasUploadManager/nasUploadManager.m

+ 1 - 0
创维盒子/双子星云手机/Class/Set/MySetViewController.h

@@ -7,6 +7,7 @@
 
 #import "BaseViewController.h"
 #import "backupsFileManager.h"
+#import "nasUploadFileManager.h"
 
 NS_ASSUME_NONNULL_BEGIN
 

+ 2 - 2
创维盒子/双子星云手机/Class/Set/MySetViewController.m

@@ -373,7 +373,7 @@
 - (void)checkDidHadUploadTaskFunWith:(NSInteger)tag
 {
     KWeakSelf
-    [[uploadFileManager shareInstance] getDataInDatabaseFun:YES complete:^(NSMutableArray * _Nonnull Arr) {
+    [[nasUploadFileManager shareInstance] getDataInDatabaseFun:YES complete:^(NSMutableArray * _Nonnull Arr) {
         mainBlock(^{
             if(Arr && Arr.count== 3){
                 NSArray *uploadingArr = Arr.firstObject;
@@ -910,7 +910,7 @@
 - (void)checkFileTransferTask
 {//有个偶现的闪退在BGFMDB
     
-    [[uploadFileManager shareInstance] checkHadUploadTaskWithComplete:^(BOOL isSuccess) {
+    [[nasUploadFileManager shareInstance] checkHadUploadTaskWithComplete:^(BOOL isSuccess) {
         self->hadUploadTaskType = isSuccess;
         [self setRightButtonRedTypeFun];
     }];

+ 1 - 1
创维盒子/双子星云手机/Class/Set/previewFile/backupsOptionViewController.m

@@ -328,7 +328,7 @@
 - (void)checkFileTransferTask
 {//有个偶现的闪退在BGFMDB
     
-    [[uploadFileManager shareInstance] checkHadUploadTaskWithComplete:^(BOOL isSuccess) {
+    [[nasUploadFileManager shareInstance] checkHadUploadTaskWithComplete:^(BOOL isSuccess) {
         self->hadUploadTaskType = isSuccess;
         [self setRightButtonRedTypeFun];
     }];

+ 1 - 1
创维盒子/双子星云手机/Class/Set/previewFile/previewAudioOrDocumentViewController.m

@@ -784,7 +784,7 @@
 - (void)checkFileTransferTask
 {//有个偶现的闪退在BGFMDB
     
-    [[uploadFileManager shareInstance] checkHadUploadTaskWithComplete:^(BOOL isSuccess) {
+    [[nasUploadFileManager shareInstance] checkHadUploadTaskWithComplete:^(BOOL isSuccess) {
         self->hadUploadTaskType = isSuccess;
         [self setRightButtonRedTypeFun];
     }];

+ 1 - 1
创维盒子/双子星云手机/Class/Set/previewFile/previewFileAndFolderSecondViewController.m

@@ -617,7 +617,7 @@
 - (void)checkFileTransferTask
 {//有个偶现的闪退在BGFMDB
     
-    [[uploadFileManager shareInstance] checkHadUploadTaskWithComplete:^(BOOL isSuccess) {
+    [[nasUploadFileManager shareInstance] checkHadUploadTaskWithComplete:^(BOOL isSuccess) {
         self->hadUploadTaskType = isSuccess;
         [self setRightButtonRedTypeFun];
     }];

+ 1 - 1
创维盒子/双子星云手机/Class/Set/previewFile/previewFileAndFolderViewController.m

@@ -833,7 +833,7 @@
 - (void)checkFileTransferTask
 {//有个偶现的闪退在BGFMDB
     
-    [[uploadFileManager shareInstance] checkHadUploadTaskWithComplete:^(BOOL isSuccess) {
+    [[nasUploadFileManager shareInstance] checkHadUploadTaskWithComplete:^(BOOL isSuccess) {
         self->hadUploadTaskType = isSuccess;
         [self setRightButtonRedTypeFun];
     }];

+ 1 - 1
创维盒子/双子星云手机/Class/Set/previewFile/previewImageOrVideoViewController.m

@@ -875,7 +875,7 @@
 - (void)checkFileTransferTask
 {//有个偶现的闪退在BGFMDB
     
-    [[uploadFileManager shareInstance] checkHadUploadTaskWithComplete:^(BOOL isSuccess) {
+    [[nasUploadFileManager shareInstance] checkHadUploadTaskWithComplete:^(BOOL isSuccess) {
         self->hadUploadTaskType = isSuccess;
         [self setRightButtonRedTypeFun];
     }];

+ 1 - 1
创维盒子/双子星云手机/Class/Set/previewFile/view/previewToUploadFileView.h

@@ -6,7 +6,7 @@
 //
 
 #import <UIKit/UIKit.h>
-
+#import "nasUploadFileManager.h"
 NS_ASSUME_NONNULL_BEGIN
 
 @interface previewToUploadFileView : UIView

+ 1 - 1
创维盒子/双子星云手机/Class/Set/previewFile/view/previewToUploadFileView.m

@@ -23,7 +23,7 @@
 -(void)checkDidHadUploadTaskFun
 {
    KWeakSelf
-   [[uploadFileManager shareInstance] getDataInDatabaseFun:YES complete:^(NSMutableArray * _Nonnull Arr) {
+   [[nasUploadFileManager shareInstance] getDataInDatabaseFun:YES complete:^(NSMutableArray * _Nonnull Arr) {
        mainBlock(^{
            if(Arr && Arr.count== 3){
                NSArray *uploadingArr = Arr.firstObject;

+ 26 - 0
创维盒子/双子星云手机/Class/Set/uploadFile/model/uploadFileDataModel.m

@@ -7,6 +7,10 @@
 
 #import "uploadFileDataModel.h"
 
+@interface uploadFileDataModel ()<NSCopying>
+
+@end
+
 @implementation uploadFileDataModel
 /**
  设置不需要存储的属性, 在模型.m文件中实现该函数.
@@ -14,4 +18,26 @@
 +(NSArray *)bg_ignoreKeys{
    return @[@"imageData",@"videoData",@"asset",@"preTimeInterval",@"curTimeInterval"];
 }
+
+- (id)copyWithZone:(NSZone *)zone
+{
+    uploadFileDataModel *model = [[self class] allocWithZone:zone];
+    
+    model.asset = self.asset;
+    model.localIdentifier = self.localIdentifier;
+    model.filename = self.filename;
+    model.videoFirstImageName = self.videoFirstImageName;
+    model.imageData = self.imageData;
+    model.videoData = self.videoData;
+    model.curUploadStateType = self.curUploadStateType;
+    model.curUploadFileType = self.curUploadFileType;
+    model.didUploadBytes = self.didUploadBytes;
+    model.totalBytes = self.totalBytes;
+    model.preTimeInterval = self.preTimeInterval;
+    model.curTimeInterval = self.curTimeInterval;
+    model.savePath = self.savePath;
+    model.bg_id = self.bg_id;
+    
+    return model;
+}
 @end

+ 1 - 0
创维盒子/双子星云手机/Class/Set/uploadFile/uploadFileView/uploadFileRecordTableView.h

@@ -8,6 +8,7 @@
 #import <UIKit/UIKit.h>
 #import "uploadFileRecordTableViewHeadView.h"
 #import "uploadFileDataModel.h"
+#import "nasUploadFileManager.h"
 
 NS_ASSUME_NONNULL_BEGIN
 

+ 1 - 1
创维盒子/双子星云手机/Class/Set/uploadFile/uploadFileView/uploadFileRecordTableView.m

@@ -447,7 +447,7 @@
     }
     
     KWeakSelf
-    [[uploadFileManager shareInstance] deleteUploadFileRecordBy:_selectModelArr withDelCache:YES complete:^(BOOL isSuccess) {
+    [[nasUploadFileManager shareInstance] deleteUploadFileRecordBy:_selectModelArr withDelCache:YES complete:^(BOOL isSuccess) {
         HLog(@"isSuccess:%d",isSuccess);
         dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0.5 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
             [SVProgressHUD dismiss];

+ 1 - 1
创维盒子/双子星云手机/NAS/NASViewController.m

@@ -812,7 +812,7 @@
 - (void)checkFileTransferTask
 {//有个偶现的闪退在BGFMDB
     
-    [[uploadFileManager shareInstance] checkHadUploadTaskWithComplete:^(BOOL isSuccess) {
+    [[nasUploadFileManager shareInstance] checkHadUploadTaskWithComplete:^(BOOL isSuccess) {
         self->hadUploadTaskType = isSuccess;
         [self setRightButtonRedTypeFun];
     }];

+ 1 - 1
创维盒子/双子星云手机/NAS/NasPreviewVideoViewController.m

@@ -768,7 +768,7 @@
 - (void)checkFileTransferTask
 {//有个偶现的闪退在BGFMDB
     
-    [[uploadFileManager shareInstance] checkHadUploadTaskWithComplete:^(BOOL isSuccess) {
+    [[nasUploadFileManager shareInstance] checkHadUploadTaskWithComplete:^(BOOL isSuccess) {
         self->hadUploadTaskType = isSuccess;
         [self setRightButtonRedTypeFun];
     }];

+ 1 - 1
创维盒子/双子星云手机/NAS/nasDownloadManager/nasDownloadFileManager.m

@@ -179,7 +179,7 @@ static nasDownloadFileManager * cur_nasDownloadFileManager = nil;
         _databaseArr = [NSMutableArray new];
     }
     
-    KWeakSelf
+    //KWeakSelf
     //dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT,0), ^{
 //    NSLock *lock = [NSLock new];
 //    [lock lock];

+ 7 - 0
创维盒子/双子星云手机/NAS/nasUploadManager/nasUploadFileManager.h

@@ -20,6 +20,9 @@ NS_ASSUME_NONNULL_BEGIN
 @property (nonatomic, strong) NSMutableArray * _Nullable fileModelDataArr;
 @property (nonatomic, strong) uploadFileDataModel *curUploadFileDataModel;//当前上传的文件
 
+@property (nonatomic, assign) NSInteger  maxUploadingNumber;//最大同时上传数 默认2
+@property (nonatomic, strong) NSMutableArray * _Nullable uploadingModelArr;//正在上传中的任务 用来做多任务处理
+
 @property (nonatomic, assign) BOOL  isSuspendType;
 @property (nonatomic, assign) BOOL  isUploadIngType;
 @property (nonatomic, assign) BOOL  isNewAddTaskType;
@@ -32,6 +35,10 @@ NS_ASSUME_NONNULL_BEGIN
 //把TZAssetModel 转成 我们需要上传的model
 - (void)handlTZAssetModelToUploadFileDataFunBy:(NSMutableArray*)indexPathsForSelectedItems complete:(custom_complete_Arr)complete;
 
+//删除本地数据库记录
+- (void)deleteUploadFileRecordBy:(NSMutableArray *)delArr withDelCache:(BOOL)isDelCache complete:(custom_complete_B)complete;
+
+- (void)checkHadUploadTaskWithComplete:(custom_complete_B)complete;
 @end
 
 NS_ASSUME_NONNULL_END

+ 231 - 10
创维盒子/双子星云手机/NAS/nasUploadManager/nasUploadFileManager.m

@@ -18,6 +18,21 @@
     return _instance;
 }
 
+- (id)init
+{
+    self = [super init];
+    if (self) {
+        [self initManager];
+    }
+    return self;
+}
+
+- (void)initManager
+{
+    _maxUploadingNumber = 2;
+    _uploadingModelArr = [NSMutableArray new];
+}
+
 #pragma mark 读取数据库数据
 - (void)getDataInDatabaseFun:(BOOL)isReGet complete:(custom_complete_Arr)complete
 {
@@ -187,6 +202,7 @@
             if(curModel.imageData)
             {
                 [cachesFileManager getFileNameWithContent:curModel.imageData fileName:curModel.filename type:uploadFileTypeImage];
+                curModel.imageData = nil;
             }
             else{
                 
@@ -266,11 +282,15 @@
     _isUploadIngType = YES;
     
     
+    if(_uploadingModelArr.count >= _maxUploadingNumber){
+        return;
+    }
+    
     _curUploadFileDataModel.imageData = nil;
     _curUploadFileDataModel.videoData = nil;
     _curUploadFileDataModel = nil;
     
-    if(_fileModelDataArr.count == 0){
+    if(_fileModelDataArr.count == 0 && _uploadingModelArr.count == 0){
         [self didUploadAllTaskDoneFun];
         return;
     }
@@ -405,17 +425,28 @@
 
 #pragma mark 开始上传
 - (void)beginGotoUploadDataFun{
+    
+    [_uploadingModelArr addObject:_curUploadFileDataModel];
+    [_fileModelDataArr removeObject:_curUploadFileDataModel];
+    __block uploadFileDataModel *curUploadModel = [_curUploadFileDataModel copy];
+    
     KWeakSelf
-    [[nasUploadManager shareInstance] beginUploadDataBy:_curUploadFileDataModel success:^(id  _Nonnull responseObject) {
-        weakSelf.curUploadFileDataModel.curUploadStateType = uploadStateDone;
-        [weakSelf nasUploadFileChangeingOneFileFunBy:weakSelf.curUploadFileDataModel];
-        [weakSelf uploadFileDoneOneFun];
+    [[nasUploadManager shareInstance] beginUploadDataBy:curUploadModel success:^(id  _Nonnull responseObject) {
+        curUploadModel.curUploadStateType = uploadStateDone;
+        [weakSelf nasUploadFileChangeingOneFileFunBy:curUploadModel];
+        [weakSelf uploadFileDoneOneFunWith:curUploadModel];
         
     } faild:^(NSError * _Nonnull error) {
-        weakSelf.curUploadFileDataModel.curUploadStateType = uploadStateFail;
-        [weakSelf nasUploadFileChangeingOneFileFunBy:weakSelf.curUploadFileDataModel];
-        [weakSelf uploadFileFailOneFun];
+        curUploadModel.curUploadStateType = uploadStateFail;
+        [weakSelf nasUploadFileChangeingOneFileFunBy:curUploadModel];
+        [weakSelf uploadFileFailOneFunWith:curUploadModel];
     }];
+    
+    //任务没饱和 再开启一个
+    if(_uploadingModelArr.count <_maxUploadingNumber)
+    {
+        [self beginUploadFileFun];
+    }
 }
 
 
@@ -500,14 +531,33 @@
 }
 
 #pragma mark 上传完成一个任务
-- (void)uploadFileDoneOneFun
+- (void)uploadFileDoneOneFunWith:(uploadFileDataModel*)dataModel
 {
+    @synchronized (self) {
+        for (uploadFileDataModel*uploadingModel in _uploadingModelArr) {
+            if(uploadingModel.bg_id.intValue == dataModel.bg_id.intValue
+               && [uploadingModel.filename isEqualToString:dataModel.filename]){
+                [_uploadingModelArr removeObject:uploadingModel];
+                break;
+            }
+        }
+    }
+    
     [self beginUploadFileFun];
 }
 
 #pragma mark 上传失败一个任务
-- (void)uploadFileFailOneFun
+- (void)uploadFileFailOneFunWith:(uploadFileDataModel*)dataModel
 {
+    @synchronized (self) {
+        for (uploadFileDataModel*uploadingModel in _uploadingModelArr) {
+            if(uploadingModel.bg_id.intValue == dataModel.bg_id.intValue
+               && [uploadingModel.filename isEqualToString:dataModel.filename]){
+                [_uploadingModelArr removeObject:uploadingModel];
+                break;
+            }
+        }
+    }
     [self beginUploadFileFun];
 }
 
@@ -518,4 +568,175 @@
     self->_curUploadFileDataModel = nil;
     [[NSNotificationCenter defaultCenter] postNotificationName:uploadFileAllTaskDoneNotification object:nil];
 }
+
+#pragma mark 删除本地数据库记录
+- (void)deleteUploadFileRecordBy:(NSMutableArray *)delArr{
+  
+//    NSMutableArray *curDelArr = [NSMutableArray arrayWithArray:delArr];
+//    for (couldPhoneFileModel *dataModel in curDelArr) {
+//        
+//        //1.内存数据删除
+//        [self handleDatabaseArrByDelete:dataModel];
+//        
+//        //2.删除数据量
+//        NSMutableString* where = [[NSMutableString alloc] initWithString:@"where "];
+//        
+//        NSString *curStr =  [NSString stringWithFormat:@"%@=%@ ",bg_sqlKey(@"bg_id"),bg_sqlValue(dataModel.bg_id)];
+//        [where appendString:curStr];
+//        
+//        [couldPhoneFileModel bg_deleteAsync:nas_box_download_tableName where:where complete:^(BOOL isSuccess) {
+//            if(isSuccess){
+//                
+//            }
+//        }];
+//        
+//        
+//        //3.取消下载
+//        NSString *urlString = dataModel.fileUrl;
+//        NSString *requestURLEncodedString = [urlString stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding];
+//        
+//        [[nasDownloadManager shareManager] deleteDownloadWithUrl:requestURLEncodedString];
+//    }
+    
+}
+
+
+#pragma mark 删除本地数据库记录
+- (void)deleteUploadFileRecordBy:(NSMutableArray *)delArr withDelCache:(BOOL)isDelCache complete:(custom_complete_B)complete
+{
+    //逻辑待优化
+//    BOOL isSuc = NO;
+//    
+//    BOOL isDelUploadingModel = NO;
+//    
+//    NSMutableArray *curDelArr = [NSMutableArray arrayWithArray:delArr];
+//    for (uploadFileDataModel *uploadFileDataMod in curDelArr) {
+//        
+//        NSMutableString* where = [[NSMutableString alloc] initWithString:@"where "];
+//        
+//        NSString *curStr =  [NSString stringWithFormat:@"%@=%@ ",bg_sqlKey(@"bg_id"),bg_sqlValue(uploadFileDataMod.bg_id)];
+//        [where appendString:curStr];
+//        isSuc = [uploadFileDataModel bg_delete:upLoadFile_image_tableName where:where];
+//        
+//        [self handleDatabaseArrByDelete:uploadFileDataMod];
+//
+//        //删除本地图片
+//        if(isSuc && isDelCache){
+//            //判断是否可以删除本地缓存
+//            if(_databaseArr && _databaseArr.count == 3 ){
+//                NSMutableArray *uploadingArr = _databaseArr[0];
+//                NSMutableArray *uploadDoneArr = _databaseArr[1];
+//                NSMutableArray *uploadFailArr = _databaseArr[2];
+//                
+//                
+//                BOOL isNeedDel = YES;
+//                for (uploadFileDataModel *baseUploadFileDataMod in uploadingArr) {
+//                    if([uploadFileDataMod.filename isEqualToString:baseUploadFileDataMod.filename] ){
+//                        isNeedDel = NO;
+//                        break;
+//                    }
+//                }
+//                
+//                if(isNeedDel){
+//                    for (uploadFileDataModel *baseUploadFileDataMod in uploadDoneArr) {
+//                        if([uploadFileDataMod.filename isEqualToString:baseUploadFileDataMod.filename] ){
+//                            isNeedDel = NO;
+//                            break;
+//                        }
+//                    }
+//                }
+//                
+//                if(isNeedDel){
+//                    for (uploadFileDataModel *baseUploadFileDataMod in uploadFailArr) {
+//                        if([uploadFileDataMod.filename isEqualToString:baseUploadFileDataMod.filename] ){
+//                            isNeedDel = NO;
+//                            break;
+//                        }
+//                    }
+//                }
+//                
+//                if(isNeedDel){
+//                    if(uploadFileDataMod.curUploadFileType == uploadFileTypeVideo){
+//                        [cachesFileManager removeItemAtPath:uploadFileDataMod.videoFirstImageName type:uploadFileTypeImage error:nil];
+//                        
+//                        [cachesFileManager removeItemAtPath:uploadFileDataMod.filename type:uploadFileTypeVideo error:nil];
+//                    }
+//                    else{
+//                        [cachesFileManager removeItemAtPath:uploadFileDataMod.filename type:uploadFileTypeImage error:nil];
+//                    }
+//                }
+//            }
+//        }
+//        
+//        if(isSuc && !isDelCache){//上传报云机已经存在文件了 查询本地是否有任务记录
+//            [self handleRetryUploadAndDelRecordFun:uploadFileDataMod];
+//        }
+//        
+//        //是否在删除上传中的任务
+//       if(_fileModelDataArr && _fileModelDataArr.count >0)
+//       {
+//           for (uploadFileDataModel *curUploadFileDataMod in _fileModelDataArr)
+//           {
+//               if(curUploadFileDataMod.bg_id.integerValue == uploadFileDataMod.bg_id.integerValue){
+//                   [_fileModelDataArr removeObject:curUploadFileDataMod];
+//                   //[self handleDatabaseArrDeteleInUploading:curUploadFileDataMod];
+//                   break;
+//               }
+//           }
+//       }
+//        
+//        if(!isDelUploadingModel){
+//            if(_curUploadFileDataModel.bg_id.integerValue == uploadFileDataMod.bg_id.integerValue){
+//                isDelUploadingModel = YES;
+//                
+//                [[webSocketManager shareInstance] suspendUploadFileFun];
+//            }
+//        }
+//    }
+//    
+//    if(isDelUploadingModel){
+//        _isUploadIngType = NO;
+//        if(_fileModelDataArr.count >=1){
+//            [self beginUploadFileFun];
+//        }
+//        else{
+//            _curUploadFileDataModel = nil;
+//            
+//            _isSuspendType = NO;
+//            //_curUploadFileDataModel.curUploadStateType = uploadStateDone;
+//        }
+//    }
+//        
+//    uploadFileDataModel *RefreshUploadFileDataMod = nil;
+//    if(delArr.count >=  1){
+//        RefreshUploadFileDataMod = delArr.firstObject;
+//    }
+//    [[NSNotificationCenter defaultCenter] postNotificationName:uploadFileRefreshNotification object:RefreshUploadFileDataMod];
+    
+    complete(YES);
+    
+}
+
+
+- (void)checkHadUploadTaskWithComplete:(custom_complete_B)complete
+{
+    [self getDataInDatabaseFun:NO complete:^(NSMutableArray * _Nonnull Arr) {
+        mainBlock(^{
+            if(!Arr || Arr.count != 3){
+                complete(NO);
+            }
+            else{
+                NSArray *firstArr = Arr[0];
+                if(firstArr.count >0){
+                    complete(YES);
+                }
+                else{
+                    complete(NO);
+                }
+            }
+        });
+        
+    }];
+}
+
 @end

+ 65 - 2
创维盒子/双子星云手机/NAS/nasUploadManager/nasUploadManager.m

@@ -6,12 +6,14 @@
 //
 
 #import "nasUploadManager.h"
+#import "AFNetworking.h"
 #import "AFNetworkReachabilityManager.h"
 #import "AFHTTPSessionManager.h"
 #import "frpUploadModel.h"
 
 @interface nasUploadManager ()
 @property(nonatomic,strong)AFHTTPSessionManager *uploadManager;
+@property (nonatomic, strong) NSURLSessionDataTask *uploadTask;
 @end
 
 @implementation nasUploadManager
@@ -45,8 +47,67 @@
     
 }
 
+//- (void)startUpload:(NSMutableDictionary *)params model:(uploadFileDataModel*)dataModel data:(NSData *)data success:(netWork_Success)success faild:(netWork_Faild)faildStr {
+//    
+//    NSString *urlString = ksharedAppDelegate.NASFileByBoxService;
+//    urlString = [[NSString alloc] initWithFormat:@"%@uploadFile",urlString];
+//    NSURL *URL = [NSURL URLWithString:urlString];
+//    NSMutableURLRequest *request = [NSMutableURLRequest requestWithURL:URL];
+//    [request setHTTPMethod:@"POST"];
+//    
+//    // 将字典转换为JSON数据
+//    NSError *error;
+//    NSData *jsonData = [NSJSONSerialization dataWithJSONObject:params options:0 error:&error];
+//      
+//    if (jsonData) {
+//        [request setHTTPBody:jsonData];
+//      
+//        // 设置请求头
+//        [request setValue:@"application/json" forHTTPHeaderField:@"Content-Type"];
+//        [request setValue:@"application/json" forHTTPHeaderField:@"Accept"];
+//      
+//        // 现在你可以使用这个request进行网络请求
+//    } else {
+//        //处理错误
+//        return;
+//    }
+//  
+//    NSInteger position = 0;
+//    if([[params allKeys] containsObject:@"position"]){
+//        NSNumber *positionNumber = params[@"position"];
+//        position = positionNumber.longValue;
+//    }
+//    
+//    // 这里应处理文件分块,此处为简化处理 验证这里OK
+//    NSURLSessionUploadTask *uploadTask = [self.uploadManager uploadTaskWithRequest:request fromData:data progress:^(NSProgress * _Nonnull uploadProgress) {
+//        HLog(@"上传222 Progress:--%@---%lld",uploadProgress,uploadProgress.completedUnitCount)
+//        dataModel.didUploadBytes = position + (uploadProgress.completedUnitCount);
+//        [[NSNotificationCenter defaultCenter] postNotificationName:uploadFileRefreshNotification object:dataModel];
+//    } completionHandler:^(NSURLResponse * _Nonnull response, id  _Nullable responseObject, NSError * _Nullable error) {
+//        
+//        frpUploadModel *model = [[frpUploadModel alloc] initWithDictionary:responseObject error:nil];
+//        
+//        if(model && model.status == 0 && model.msg.length > 0){
+//            success(responseObject);
+//            HLog(@"%@ 上传完成 :--%@",dataModel.filename,responseObject)
+//        }
+//        else{
+//            faildStr(error);
+//            HLog(@"%@ 上传失败 :--%@",dataModel.filename,error)
+//        }
+//    }];
+//  
+//    self.uploadTask = uploadTask;
+//    [uploadTask resume];
+//    
+//}
+
 - (void)nasUploadFileToFileServiceWithParams:(NSMutableDictionary *)params model:(uploadFileDataModel*)dataModel data:(NSData *)data success:(netWork_Success)success faild:(netWork_Faild)faildStr {
     
+    //test code
+//    [self startUpload:params model:dataModel data:data success:success faild:faildStr];
+//    return;
+    
     NSString *urlString = ksharedAppDelegate.NASFileByBoxService;
     urlString = [[NSString alloc] initWithFormat:@"%@uploadFile",urlString];
     
@@ -58,14 +119,16 @@
     
     HLog(@"上传地址:%@---%@---position:%ld--",urlString,params,position);
     
-    [_uploadManager POST:urlString parameters:params constructingBodyWithBlock:^(id<AFMultipartFormData>  _Nonnull formData) {
+    self.uploadTask = [_uploadManager POST:urlString parameters:params constructingBodyWithBlock:^(id<AFMultipartFormData>  _Nonnull formData) {
         
         NSString *mimeType =@"application/octet-stream";
         if ([[params allKeys] containsObject:@"imageType"]) {
             mimeType = @"image/jpeg";
+            //mimeType = @"jpg";
         }
         else if ([[params allKeys] containsObject:@"videoType"]) {
-            mimeType = @"video/mp4";
+            //mimeType = @"video/mp4";
+            mimeType = @"video";
         }
         
         [formData appendPartWithFileData:data name:@"file" fileName:params[@"filename"] mimeType:mimeType];