首次使用或应用程序进入后台时下载失败

时间:2016-11-04 12:34:32

标签: ios iphone swift2 alamofire

Alamofire 3.5.0,Swift2.2

我正在使用Alamofire下载方法下载ZIP文件,我注意到当我开始下载过程并且应用程序变为后台时,下载失败并出现以下错误:

----------------------
error Optional(Error Domain=NSCocoaErrorDomain Code=4
    "“CFNetworkDownload_pZ56nc.tmp” couldn’t be moved to “courses”
    because either the former doesn't exist, or the folder containing
    the latter doesn't exist." UserInfo=
    {NSSourceFilePathErrorKey=
/private/var/mobile/Containers/Data/Application/[UUID]/tmp/CFNetworkDownload_pZ56nc.tmp, 
    NSUserStringVariant=(
        Move
    ),     
    NSDestinationFilePath=
/var/mobile/Containers/Data/Application/[UUID]/Library/courses/course_302.zip, 
    NSFilePath=
/private/var/mobile/Containers/Data/Application/[UUID]/tmp/CFNetworkDownload_pZ56nc.tmp, 
    NSUnderlyingError=0x13f52f990 {Error Domain=NSPOSIXErrorDomain
    Code=2 "No such file or directory"}})
----------------------

这是下载文件的代码:

//...
var userLibraryPath:String = {
    return NSSearchPathForDirectoriesInDomains(.LibraryDirectory, .UserDomainMask, true)[0]
}()

//...
let _coursePath:NSURL = NSURL(string: "file://\(userLibraryPath)/)")!
//...
let zipURL = _coursePath.URLByAppendingPathComponent("course_\(courseId).zip")
        //if file exists destroy it
        if let zipPath = zipURL?.path where NSFileManager.defaultManager().fileExistsAtPath(zipPath) {
            do {
                try NSFileManager.defaultManager().removeItemAtPath(zipPath)
            } catch let error as NSError {
                print(error)
            }
        }
        //
        let downloadRequest = Alamofire.download(Router.download(courseId), destination: { (url:NSURL, urlResponse:NSHTTPURLResponse) -> NSURL in
            //
            return zipURL!
            //
        }).progress({ (bytesWritten, totalBytesWritten, totalBytesExpectedToWrite) in
            //
            let progress = Double(totalBytesWritten) / Double(totalBytesExpectedToWrite)

            dispatch_async(GlobalMainQueue, {
                self.notifyDownloadProgress(courseId, progress: progress)
            })

        }).response(completionHandler: { (request:NSURLRequest?, response:NSHTTPURLResponse?, data:NSData?, error:NSError?) in
            self.removeFromQueue(courseId)
            print("response")
            print("----------------------")
            print("error \(error)")
            print("----------------------")
            //here I would try to extract it
})

更新我刚刚在iPhone 5上测试了应用程序的全新安装,并且它不必转到后台(例如通过主页按钮)失败,它在第一次加载时失败(以及任何后续的)直到应用程序被杀死并重新打开后。

为什么将“/ private”位添加到路径中?我在这里做错了什么?

1 个答案:

答案 0 :(得分:1)

实际上它是一个"没有这样的文件或目录"错误。

当我添加时:

//
let downloadRequest = Alamofire.download(Router.download(courseId), destination: { (url:NSURL, urlResponse:NSHTTPURLResponse) -> NSURL in
    let course = zipURL!.URLByDeletingLastPathComponent!.path!
    let fm = NSFileManager.defaultManager()
    var isDir:ObjCBool = false
    if(fm.fileExistsAtPath(path, isDirectory: &isDir) == false){
       //doesnt exist
       do {
           try fm.createDirectoryAtPath(path, withIntermediateDirectories: true, attributes: nil)
       } catch let error as NSError {
           //
           print(error)
       }
    }

    return zipURL!
    //
 })