«Операция не может быть завершена (ошибка Какао 512.)» - PullRequest
6 голосов
/ 03 марта 2012

У меня есть этот код, который должен работать отлично, но я не могу понять, почему это не так:

+(NSString *)writeImageToFile:(UIImage *)image {

    NSData *fullImageData = UIImageJPEGRepresentation(image, 1.0f);


    NSString *path = [NSHomeDirectory() stringByAppendingPathComponent:@"Documents/Images/"];

    NSFileManager *fileManager = [NSFileManager defaultManager];
    BOOL isDirectory = NO;
    BOOL directoryExists = [fileManager fileExistsAtPath:path isDirectory:&isDirectory];
    if (directoryExists) {
        NSLog(@"isDirectory: %d", isDirectory);
    } else {
        NSError *error = nil;
        BOOL success = [fileManager createDirectoryAtPath:path withIntermediateDirectories:NO attributes:nil error:&error];
        if (!success) {
            NSLog(@"Failed to create directory with error: %@", [error description]);
        }
    }

    NSString *name = [NSString stringWithFormat:@"%@.jpg", [JEntry generateUuidString]];
    NSString *filePath = [path stringByAppendingPathComponent:name];
    NSError *error = nil;
    BOOL success = [fullImageData writeToFile:filePath options:NSDataWritingAtomic error:&error];
    if (!success) {
        NSLog(@"Failed to write to file with error: %@", [error description]);
    }

    return filePath;
}

Он передал directoryExists без ошибки, но когда он попадает в writeToFile,это дает мне эту ошибку:

Error Domain=NSCocoaErrorDomain Code=512 "The operation couldn’t be completed. (Cocoa error 512.)" UserInfo=0x5634ee0 {NSFilePath=/var/mobile/Applications/5E25F369-9E05-4345-A0A2-381EDB3321B8/Documents/Images/18DAE0BD-6CB4-4244-8ED1-9031393F6DAC.jpg, NSUnderlyingError=0x5625010 "The operation couldn’t be completed. Not a directory"}

Есть идеи, почему это может быть?

Ответы [ 3 ]

8 голосов
/ 03 марта 2012

Я смог воспроизвести вашу ошибку, когда сначала записывал файл по пути @"Documents/Images/", а затем пытался записать изображение, используя ваш код.

Я думаю, что есть два возможных сценария для этого:

1) Вы создали этот файл по ошибке при предыдущем запуске вашего приложения. Это будет решено, если вы сбросите симулятор с помощью меню: iOS Simulator> Сбросить содержимое и настройки и удалите приложение с вашего устройства: Длительное нажатие> нажмите на символ x .

2) Где-то в вашем приложении есть код, который создает этот файл. Если это так, вы должны найти этот код и удалить его.

3 голосов
/ 03 марта 2012

С FoundationErrors.h :

NSFileWriteUnknownError = 512

Попробуйте использовать withIntermediateDirectories:YES.

1 голос
/ 17 июля 2013

В моем случае точка '.'в имени каталога (например, ~ / Documents / someDir.dir / somefile) был причиной проблемы.Я удалил оскорбительный символ, и ошибка исчезла.

...