2012-04-24 9 views
7

मैं दो तरह के ड्रॉपबॉक्स सिंक ऐप का निर्माण कर रहा हूं। मैं मूल डेटा से वस्तुओं को लोड करता हूं, उन्हें JSON में परिवर्तित करता हूं और उन्हें ड्रॉपबॉक्स पर भेजता हूं। हालांकि, जब मैं सिंक करता हूं, तो मैं स्थानीय JSON फ़ाइलों के एक सेट को ड्रॉपबॉक्स JSON फ़ाइलों में तुलना करता हूं। यदि कोई विवाद पता चला है, तो एक सिंक तर्क लागू होता है। सिंक तर्क के परिणामस्वरूप, एक दूरस्थ JSON फ़ाइल डाउनलोड की जा सकती है और स्थानीय JSON फ़ाइल को प्रतिस्थापित कर देगी।आईफोन रीस्टकिट स्थानीय JSON फ़ाइल को लोड करने और इसे कोर डेटा इकाई में कैसे मैप करें?

तो मैं स्थानीय दस्तावेज़ निर्देशिका में JSON फ़ाइलों का एक समूह के साथ समाप्त होता हूं।

मैं स्थानीय JSON फ़ाइलों को मैपिंग का उपयोग करके ऑब्जेक्ट्स में वापस deserialize करने के लिए RestKit का उपयोग कैसे कर सकता हूं? RKTwitterCoreData वेब-आधारित JSON से कोर डेटा इकाई बनाता है। मैं स्थानीय JSON फ़ाइल के साथ ऐसा करने की कोशिश कर रहा हूं।

loadObjects तरीकों में से एक गुच्छा रहे हैं, लेकिन उन सभी को वेब कॉल के साथ काम करने के लिए दिखाई देते हैं:

- (RKObjectLoader*)loadObjectsAtResourcePath:(NSString*)resourcePath delegate:(id<RKObjectLoaderDelegate>)delegate; 

धन्यवाद!

+0

क्या आपने loadObjectsAtResourcePath विधि के लिए स्थानीय पथ पारित करने का प्रयास किया है? – shannoga

उत्तर

0

कोर डेटा रूपांतरण के लिए जेएसओएन से कोर डेटा के लिए मैं इसका उपयोग कर रहा हूं।

-(void)deserializeFileAtPath:(NSString*)filePath 
{ 
    DLog(@"Deserialize file: %@",filePath); 
    NSError* error = nil; 
    NSString *stringJSON = [NSString stringWithContentsOfFile:filePath usedEncoding:nil error:&error]; 
    if(error) 
    { 
     NSLog(@"Error reading from file: %@", filePath); 
    } 

    //restore the dictionary, as it was serialized 
    NSDictionary* serializationDictionary = [NSJSONSerialization JSONObjectWithData:[NSData dataWithContentsOfFile:filePath] options:NSJSONReadingMutableContainers error:&error]; 

    //Here you must ensure that your object mapping exists 
    [CoreDataWrapper setupCoreDataObjectMapping]; 

//top level object within JSON it will have one entity that you really want to deserialize. Without a wrapper, the mapper would not know what the top level entity really is 
    CoreDataWrapper* wrapper = [CoreDataWrapper object]; 

    RKObjectMapper* mapper; 
    error = nil; 

//this performs deserialization. if you get errors about designated initializer not being called, you have setup a wrong object mapping. You need to define RKManagedObjectMapping for your core data classes 
    mapper = [RKObjectMapper mapperWithObject:serializationDictionary 
           mappingProvider:[RKObjectManager sharedManager].mappingProvider]; 
    RKObjectMappingResult* result = [mapper performMapping]; 

    //top level object within wrapper that holds the real payload 
    RealCoreDataEntity* realCoreData = [result asObject]; 
    realCoreData.wrapper = wrapper; 

//just in case 
    [[wrapper managedObjectContext]save:nil]; 

//prints what we got back 
    DLog(@"%@", realCoreData); 

//prints any nested relationships 
    for(NestedRelationshipObject* relationshipEntity in realCoreData.relationship) 
    { 
     DLog(@"Nested entity:%@", relationshipEntity); 
    } 

} 

यहां नेस्टेड रेस्टकिट ऑब्जेक्ट मॉडल को परिभाषित करने का तरीका बताया गया है। जब इस संरचना की एक JSON फ़ाइल deserialized किया जा रहा है, यह स्वचालित रूप से आपके लिए सभी घोंसले संबंध बना देगा, और प्रबंधित ऑब्जेक्ट संदर्भों को मर्ज भी करेगा!

+(void)setupCoreDataObjectMapping 
{ 

RKObjectManager *objectManager = [RKObjectManager sharedManager ] ; 

// Setup our object mappings  
/*! 
Mapping by entity. Here we are configuring a mapping by targetting a Core Data entity with a specific 
name. This allows us to map back Twitter user objects directly onto NSManagedObject instances -- 
there is no backing model class! 
*/ 
//********************************  
RKManagedObjectMapping* nestedRelationshipMapping = [RKManagedObjectMapping mappingForEntityWithName:@"NestedRelationshipObject"]; 
//UUID determines which objects get updated and which ones get created during the mapping process 
nestedRelationshipMapping.primaryKeyAttribute = @"uuid"; 
[nestedRelationshipMapping mapKeyPathsToAttributes: 
@"IKeepTheseTheSame", @"IKeepTheseTheSame", 
@"AnotherValue",@"AnotherValue", 
//keep adding your attributes 
nil]; 
[objectManager.mappingProvider addObjectMapping:nestedRelationshipMapping]; 




//********************************  

RKManagedObjectMapping* mainPayloadMapping = [RKManagedObjectMapping mappingForEntityWithName:@"RealCoreDataEntity"]; 
mainPayloadMapping.primaryKeyAttribute = @"uuid"; 
[mainPayloadMapping mapKeyPathsToAttributes: 
@"companyName",@"companyName", 
//keep adding your attributes 
nil]; 


//this is the main payload. I create all of it's relationships before, and then add them to the mapping. 
[mainPayloadMapping mapRelationship:@"relationshipName" withMapping:nestedRelationshipMapping]; 
[objectManager.mappingProvider addObjectMapping:mainPayloadMapping]; 


[objectManager.mappingProvider setSerializationMapping:[mainPayloadMapping inverseMapping] forClass:[YourNSManagedObjectSubclass class]]; 


[objectManager.mappingProvider setMapping:nestedRelationshipMapping forKeyPath:@"mainPayloadToNestedDataRelationshipName"]; 
[objectManager.mappingProvider setMapping:mainPayloadMapping forKeyPath:@"wrapperToMainPayloadRelationshipName"]; 


//this is a top level JSON object. It's name will not be identified within the object, but it's relationshipName will be. The result of deserializing this object would be an object that is being wrapped. 
RKManagedObjectMapping* wrapperMapping = [RKManagedObjectMapping mappingForClass:[IconFileWrapper class]]; 
iconWrapperMapping.primaryKeyAttribute = @"uuid"; 
// keyPath and attribute names. must be even 
[iconWrapperMapping mapKeyPathsToAttributes:@"uuid",@"uuid",nil]; 
//keep adding your attributes 
[iconWrapperMapping mapRelationship:@"relationshipName" withMapping:mainPayloadMapping]; 

[objectManager.mappingProvider addObjectMapping:wrapperMapping]; 
[objectManager.mappingProvider setSerializationMapping:[wrapperMapping inverseMapping] forClass:[YourWrapperNSManagedObjectSubclass class]]; 


} 
6

यह रेस्ट-किट दस्तावेज़ों से है, अभी तक यह कोशिश नहीं की है, लेकिन यह एक JSON स्ट्रिंग का उपयोग शुरू होने की तरह दिखता है।

आप इसे यहाँ पा सकते हैं: look at the bottom of the page

NSString* JSONString = @"{ \"name\": \"The name\", \"number\": 12345}"; 
NSString* MIMEType = @"application/json"; 
NSError* error = nil; 
id<RKParser> parser = [[RKParserRegistry sharedRegistry] parserForMIMEType:MIMEType]; 
id parsedData = [parser objectFromString:JSONString error:&error]; 
if (parsedData == nil && error) { 
    // Parser error... 
} 


RKObjectMappingProvider* mappingProvider = [RKObjectManager sharedManager].mappingProvider; 
RKObjectMapper* mapper = [RKObjectMapper mapperWithObject:parsedData mappingProvider:mappingProvider]; 
RKObjectMappingResult* result = [mapper performMapping]; 
if (result) { 
    // Yay! Mapping finished successfully 
} 

संपादित rob5408 टिप्पणी संदर्भ बचत के बारे में देखें:

[[RKObjectManager sharedManager].objectStore.managedObjectContext save:&error]; 
+0

महान काम किया। धन्यवाद! – jcanfield55

+1

धन्यवाद @ शन्नोगा, यह बहुत उपयोगी था। मैं यह ध्यान रखना चाहता हूं कि ऑब्जेक्ट्स को जारी रखने के लिए मुझे बाद में कोर डेटा संदर्भ को सहेजना पड़ा। [[RKObjectManager साझा प्रबंधक] .objectStore.managedObjectContext सहेजें: और त्रुटि]; – rob5408

+0

ग्रेट, धन्यवाद @ rob5408 आपके नोट के लिए इसे उत्तर में जोड़ा गया – shannoga

1

आप के रूप में ठीक उसी व्यवहार करना चाहते हैं " डिफ़ॉल्ट "Restkit फ़ंक्शन - (void)objectLoader:(RKObjectLoader*)objectLoader didLoadObjects:(NSArray*)objects आप इसका उपयोग मूल्यवान objects NSArray प्राप्त करने के लिए कर सकते हैं:

RKObjectMappingResult* result = [mapper performMapping]; 
NSArray* objects = [result asCollection]; 
संबंधित मुद्दे