tutorial objective framework basics ios objective-c swift cocoa

ios - objective - Obtenga una ruta de acceso a la carpeta de soporte de aplicaciones mediante programaciĆ³n



swift documentation (7)

Estoy tratando de obtener un NSString para la carpeta de soporte de aplicaciones del usuario.

Sé que puedo hacer NSString *path = @"~/Library/Application Support"; pero esto no parece muy elegante. He jugado con el uso de NSSearchPathForDirectoriesInDomains pero parece ser bastante prolijo y crea varios objetos innecesarios (al menos, mi implementación sí lo hace).

¿Hay una manera simple de hacer esto?


Cree una clase C objetivo por separado para leer y escribir en el directorio de documentos. Evitaré volver a escribir el código. A continuación está mi versión de esto.

//Directory.h #import <Foundation/Foundation.h> #import <UIKit/UIKit.h> #define PATH (NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES)) #define BASEPATH (([PATH count] > 0)? [PATH objectAtIndex:0] : nil) @interface DocumentsDirectory : NSObject //Here you can also use URL path as return type and file path. +(void)removeFilesfromDocumentsDirectory:(NSString*)filename; +(NSString*)writeFiletoDocumentsDirectory:(NSString*)filename; @end #import "Directory.h" @implementation DocumentsDirectory UIAlertView *updateAlert; +(void)removeFilesfromDocumentsDirectory:(NSString*)filename { NSFileManager *fileManager = [NSFileManager defaultManager]; NSString *filePath = [BASEPATH stringByAppendingPathComponent:filename]; NSError *error; BOOL success = [fileManager removeItemAtPath:filePath error:&error]; //Remove or delete file from documents directory. if (success) { updateAlert= [[UIAlertView alloc] initWithTitle:@"Congratulations:" message:@"File is updated successfully" delegate:self cancelButtonTitle:@"OK" otherButtonTitles:nil]; [updateAlert show]; } else { NSLog(@"Could not delete file -:%@ ",[error localizedDescription]); updateAlert= [[UIAlertView alloc] initWithTitle:@"Try again:" message:[error localizedDescription] delegate:self cancelButtonTitle:@"OK" otherButtonTitles:nil]; [updateAlert show]; } } +(NSString*)writeFiletoDocumentsDirectory:(NSString*)filename { NSString *foldDestination = BASEPATH; NSString *filePath = [foldDestination stringByAppendingPathComponent:filename]; return filePath; } @end


Esto es lo que uso para obtener la base de datos. Lo obtuve de la clase de Stanford. Podría ayudar a alguien.

NSURL *url = [[[NSFileManager URLsForDirectory:NSDocumentDirectory inDomains:NSUserDomainMask] lastObject]; url = [url URLByAppendingPathComponent:@"database_name"]; NSLog(@"Database URL: %@",url);


Esto funciona para mí:

NSError *error; NSURL* appSupportDir = [[NSFileManager defaultManager] URLForDirectory:NSApplicationSupportDirectory inDomain:NSUserDomainMask appropriateForURL:nil create:YES error:&error];


La mejor práctica es utilizar NSSearchPathForDirectoriesInDomains con NSApplicationSupportDirectory como "long winded", ya que puede ser.

Ejemplo:

NSArray *paths = NSSearchPathForDirectoriesInDomains(NSApplicationSupportDirectory, NSUserDomainMask, YES); NSString *applicationSupportDirectory = [paths firstObject]; NSLog(@"applicationSupportDirectory: ''%@''", applicationSupportDirectory);

Salida NSLog:

applicationSupportDirectory: ''/Volumes/User/me/Library/Application Support''


Solo para garantizar que las personas comiencen a usar la forma recomendada de hacerlo:

- (NSArray<NSURL *> * _Nonnull)URLsForDirectory:(NSSearchPathDirectory)directory inDomains:(NSSearchPathDomainMask)domainMask

Ejemplo expandido de la documentación:

- (NSURL*)applicationDataDirectory { NSFileManager* sharedFM = [NSFileManager defaultManager]; NSArray* possibleURLs = [sharedFM URLsForDirectory:NSApplicationSupportDirectory inDomains:NSUserDomainMask]; NSURL* appSupportDir = nil; NSURL* appDirectory = nil; if ([possibleURLs count] >= 1) { // Use the first directory (if multiple are returned) appSupportDir = [possibleURLs objectAtIndex:0]; } // If a valid app support directory exists, add the // app''s bundle ID to it to specify the final directory. if (appSupportDir) { NSString* appBundleID = [[NSBundle mainBundle] bundleIdentifier]; appDirectory = [appSupportDir URLByAppendingPathComponent:appBundleID]; } return appDirectory; }

Enlace de prueba: https://developer.apple.com/library/ios/documentation/FileManagement/Conceptual/FileSystemProgrammingGuide/AccessingFilesandDirectories/AccessingFilesandDirectories.html#//apple_ref/doc/uid/TP40010672-CH3-SW3


Swift 3:

FileManager.default.urls(for: .applicationSupportDirectory, in: .userDomainMask).first


Swift 4:

print(NSHomeDirectory())

o

print(FileManager.default.urls(for: .applicationSupportDirectory, in: .userDomainMask).first)

y

let yourString = String(FileManager.default.urls(for: .applicationSupportDirectory, in: .userDomainMask).first)