簡介:
我們在開發中,一般在視頻類的app或者與硬件交互的app中會有將數據文件上傳到云端,少數社交app上傳圖片也比較多。下面講的是將數據文件(txt類型)切片儲存到本地并逐片上傳到云端模仿斷點續傳的機制,但事實上,這個操作并不是真正的斷點續傳。
google了一下,關于切分的文章也蠻多,但是都比較雷同,接下來要分享將數據寫進txt并切片儲存到本地,一片一片傳到云端的整個流程。下面話不多說了,來一起看看詳細的介紹吧。
步驟:
1、將獲取到的數據寫進文件(總文件)
2、將總文件按照需求分割并儲存到本地
3、創建數據庫(保存分片數據的ID、路徑等)
4、根據路徑去本地將分片的數據上傳到云端
代碼:
一、將獲取到的數據寫進文件
//設置文件路徑NSString *folder = @"xxx" ;//創建文件夾[FileUtils createFolderIfNotExist:folder];//獲取沙盒路徑并且拼接文件路徑NSString *documentsDirectory= [NSHomeDirectory() stringByAppendingPathComponent:@"Documents"];NSString *fileName = [NSString stringWithFormat:@"xxx"];NSString *path = [folder stringByAppendingString:文件名];NSString *realPath = [documentsDirectory stringByAppendingString:path];//存總數據NSFileManager *fileManager = [NSFileManager defaultManager];[fileManager createFileAtPath: realPath contents:文件數據 attributes:nil];
二、將總文件按照需求分割并儲存到本地
這里你首先要建立數據庫表格、設置數據庫路徑,不熟悉語法可以參考iOS數據庫FMDB--增刪改查(模糊查詢)詳細介紹
開始分片:這里是用指針的原理
uint32_t point = 0; //移動指針double offset = 300*1024; //偏移量300kbdouble trunkCountFloat = fileDataLength/offset; //分片塊數uint32_t trunkCount = trunkCountFloat; //求出浮點型片數
提示:uint32_t為32位無符號類型數據。先初始化一個指針變量,設置偏移量:
1M=1024KB
1KB=1024B
So,1M等于 1024*1024,如果想設置一次切500 KB 就是 500 *1024;
開始分割:原理如下
有兩種情況:
1)可能數據比較小,只切割了一片
if (fileDataLength <= offset) { //只有一片 //插入數據庫列表}
2)切割后大于一片
for(NSUInteger i = 0; i<trunkCount; i++) { NSData *trunkdata ; if (i == (trunkCount-1)){ //最后一片 trunkdata = [fileData subdataWithRange:NSMakeRange(point, fileDataLength -point)]; }else{ trunkdata = [fileData subdataWithRange:NSMakeRange(point, offset)]; } }
每切一片就將指針向前移動一次
point += offset;
存數據并插入數據庫
[fileManager createFileAtPath:分片數據路徑 contents:分片數據 attributes:nil];//插入數據庫 ...
如果需要對分割好的數據進行加密,在這一步就可以進行~
三、上傳分片數據
這里順帶加上上傳的代碼:
1)先查詢數據庫有沒有需要上傳的代碼,有就請求接口上傳,每上傳成功一片就將數據庫對應的分片數據的上傳狀態碼改變,失敗就重新請求接口上傳,請求的接口一般都需要告訴云端app一共切了多少片數據、片運動數據ID、正在上傳第幾片等。
app可以與云端商量好一種校驗方式,比較保證數據安全上傳~
上傳的代碼:(其中一種上傳方式)
//拼接數據表單NSMutableURLRequest *request = [[AFHTTPRequestSerializer serializer] multipartFormRequestWithMethod:@"POST" URLString:urlStr parameters:dic constructingBodyWithBlock:^(id<AFMultipartFormData > formData) { [formData appendPartWithFileData:txt文件數據 name:字段 fileName:txt文件名 mimeType:@"text"]; } error:&error]; if (error) { DLog(@"拼接表單失敗"); } //上傳 AFURLSessionManager *manager = [[AFURLSessionManager alloc] initWithSessionConfiguration:[NSURLSessionConfiguration defaultSessionConfiguration]]; manager.operationQueue.maxConcurrentOperationCount = 1; manager.responseSerializer = [AFJSONResponseSerializer serializer]; NSURLSessionUploadTask *uploadTask; uploadTask = [manager uploadTaskWithStreamedRequest:request progress:^(NSProgress * _Nonnull uploadProgress) { }completionHandler:^(NSURLResponse * _Nonnull response, id _Nullable responseObject, NSError * _Nullable error) { //成功的回調 complete(jsonBackDic); //失敗的回調 fail(error.localizedDescription,error.code); }]; //最后一定要寫上這句代碼啟動 [uploadTask resume];
注意:這里最好做一個防止數據重復上傳的處理,可以作個判斷,初始化一個有序數組NSMutableSet,如果該分片數據沒有上傳就將分片數據的ID加進一個有序數組里并執行上傳代碼,當上傳失敗就將分片數據的ID從有序數組移除并再次發起上傳請求。
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對VEVB武林網的支持。
新聞熱點
疑難解答