Savez-vous comment partager des données de base avec deux applications (dont vous êtes le propriétaire) permettant de lire et d'écrire dans le même fichier .sqlite?Accès aux données partagées à partir de deux applications
J'ai essayé d'utiliser des groupes App:
1) Bank.xcdatamodeld BankInfo.swift BankDetails.swift
J'ai copié ces fichiers dans le répertoire pour le projet de cette application B (extraient des le projet de l'application A), puis je les ai traînés dans Xcode.
2) Je l'ai récupéré le fichier SQLite à partir du sandbox commun des groupes d'applications
délégué App: Core Data pile [Swift]
lazy var applicationDocumentsDirectory: NSURL = {
let urls = NSFileManager.defaultManager().URLsForDirectory(.DocumentDirectory, inDomains: .UserDomainMask)
return urls[urls.count-1] as NSURL
}()
lazy var managedObjectModel: NSManagedObjectModel = {
let modelURL = NSBundle.mainBundle().URLForResource("shareapps", withExtension: "momd")!
return NSManagedObjectModel(contentsOfURL: modelURL)!
}()
lazy var persistentStoreCoordinator: NSPersistentStoreCoordinator? = {
// Create the coordinator and store
var coordinator: NSPersistentStoreCoordinator? = NSPersistentStoreCoordinator(managedObjectModel: self.managedObjectModel)
let directory = NSFileManager.defaultManager().containerURLForSecurityApplicationGroupIdentifier("com.sd.shareapps");
let url = directory?.URLByAppendingPathComponent("shareapps.sqlite")
//Sarting frehs every time
NSFileManager.defaultManager().removeItemAtURL(url!, error: nil)
var error: NSError? = nil
var failureReason = "There was an error creating or loading the application's saved data."
if coordinator!.addPersistentStoreWithType(NSSQLiteStoreType, configuration: nil, URL: url, options: nil, error: &error) == nil {
coordinator = nil
// Report any error we got.
let dict = NSMutableDictionary()
dict[NSLocalizedDescriptionKey] = "Failed to initialize the application's saved data"
dict[NSLocalizedFailureReasonErrorKey] = failureReason
dict[NSUnderlyingErrorKey] = error
error = NSError(domain: "YOUR_ERROR_DOMAIN", code: 9999, userInfo: dict)
// Replace this with code to handle the error appropriately.
// abort() causes the application to generate a crash log and terminate. You should not use this function in a shipping application, although it may be useful during development.
NSLog("Unresolved error \(error), \(error!.userInfo)")
abort()
}
println("\(coordinator?.persistentStores)")
return coordinator
}()
lazy var managedObjectContext: NSManagedObjectContext? = {
let coordinator = self.persistentStoreCoordinator
if coordinator == nil {
return nil
}
var managedObjectContext = NSManagedObjectContext()
managedObjectContext.persistentStoreCoordinator = coordinator
return managedObjectContext
}()
J'ai ce message d'erreur :
"*** Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: '+entityForName: nil is not a legal NSPersistentStoreCoordinator for searching for entity name 'Entity'"
Cordialement
Lorsque vous créez votre contexte d'objet géré, lui attribuez-vous un coordinateur de magasin persistant valide? (Quel est le code pour ce look?) –
'' 'var var managedObjectContext: NSManagedObjectContext? = { laissez le coordinateur = self.persistentStoreCoordinator si coordonnateur == {nul retour nul } var managedObjectContext = NSManagedObjectContext() managedObjectContext.persistentStoreCoordinator = coordinateur retour managedObjectContext }() '' 'Les accidents d'applications sans passer à mon point d'arrêt dans la pile de base de données. Je ne suis pas sûr de procéder au bon chemin. – Hobbes