2012-08-10 6 views
-1

J'essaye d'envoyer l'objet de json au serveur. Mais j'ai reçu une erreur et je ne peux pas le réparer.Erreur NSJSONSerialization

-(void) connectToHost{ 
CFReadStreamRef readStream; 
CFWriteStreamRef writeStream; 
CFStreamCreatePairWithSocketToHost(NULL, (CFStringRef)@"localhost", 9123, &readStream, &writeStream); 
inputStream = (__bridge NSInputStream *)readStream; 
outputStream = (__bridge NSOutputStream *)writeStream; 
[inputStream setDelegate:self]; 
[outputStream setDelegate:self]; 
[inputStream scheduleInRunLoop:[NSRunLoop currentRunLoop] forMode:NSDefaultRunLoopMode]; 
[outputStream scheduleInRunLoop:[NSRunLoop currentRunLoop] forMode:NSDefaultRunLoopMode]; 
[inputStream open]; 
[outputStream open]; } 

Ceci est ma connexion à l'hôte.

NSDictionary *setUser = [NSDictionary 
      dictionaryWithObjectsAndKeys:[@"u" stringByAppendingString:my.id],@"id", 
             @"GET_USER_INFO",@"command", 
             @"",@"value", 
             nil]; 
    NSArray *array = [NSArray arrayWithObject:setUser]; 
    jsonDataToSendTheServer = [array JSONRepresentation]; 
    NSLog(@" %@ ", jsonDataToSendTheServer); 
    // array = [NSArray arrayWithObject:jsonDataToSendTheServer]; 
    NSLog(@" %@ ", array); 
    NSLog(@"true or false %c",[NSJSONSerialization 
           isValidJSONObject: array]); 

    bytesWritten = [NSJSONSerialization writeJSONObject:array toStream:outputStream options:NSJSONWritingPrettyPrinted error:nil]; 

et cette partie fait partie NSJSONSerialization. Cependant, j'ai eu une erreur.

*** Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: '***+[NSJSONSerialization writeJSONObject:toStream:options:error:]: stream is not open for writing' 

Je suis nouveau chez objective-c. Je ne peux pas résoudre le problème pendant 3 heures.

=======================================

modifier:

- (void)stream:(NSStream *)theStream handleEvent:(NSStreamEvent)streamEvent { 

NSLog(@"stream event %i", streamEvent); //this doesn't post in the log when stream opened... 
NSLog(@"bytes %i",bytesWritten); 
switch (streamEvent) { 

    case NSStreamEventOpenCompleted: 
     NSLog(@"Stream opened"); 
     break; 
    case NSStreamEventHasBytesAvailable: 

     if (theStream == inputStream) { 

      uint8_t buffer[1024]; 
      int len; 

      while ([inputStream hasBytesAvailable]) { 
       len = [inputStream read:buffer maxLength:sizeof(buffer)]; 
       if (len > 0) { 

        NSString *output = [[NSString alloc] initWithBytes:buffer length:len encoding:NSUTF8StringEncoding]; 

        if (nil != output) { 

         NSLog(@"server said: %@", output); 
         //[self messageReceived:output]; 

        } 
       } 
      } 
     } 
     break; 

    case NSStreamEventEndEncountered: 

     [theStream close]; 
     [theStream removeFromRunLoop:[NSRunLoop currentRunLoop] forMode:NSDefaultRunLoopMode]; 
     //[theStream release]; 
     theStream = nil; 

     break; 
    case NSStreamEventHasSpaceAvailable: 
    { 
     uint8_t *readBytes = (uint8_t *)[_data mutableBytes]; 
     readBytes += bytesWritten; // instance variable to move pointer 
     int data_len = [_data length]; 
     unsigned int len = ((data_len - bytesWritten >= 1024) ? 
          1024 : (data_len-bytesWritten)); 
     uint8_t buf[len]; 
     (void)memcpy(buf, readBytes, len); 
     //len = [theStream write:(const uint8_t *)buf maxLength:len]; 
     NSLog(@"written %s", buf); 
     bytesWritten += len; 
    } 
     break; 

    case NSStreamEventErrorOccurred: 
    { 
     NSLog(@"no connection"); 
    } 
    case NSStreamEventNone: 
    { 
     //printf("EVENT: None.\n"); 
     break; 
    } 

    default: 
     NSLog(@"Unknown event"); 
}} 

ceci est mon flux: handleEvent: fonction.

Maintenant, après avoir ajouté la connectionToHost à déléguer, j'ai ce genre d'erreur.

012-08-10 16:14:27.302 TaraftarlikOyunu[2274:c07] written P∏◊P‡ˇø 

2012-08-10 16:14:28.399 TaraftarlikOyunu[2274:c07] benim bu id 587127341 

2012-08-10 16:14:28.399 TaraftarlikOyunu[2274:c07] benim ad Ahmet 

2012-08-10 16:14:28.400 TaraftarlikOyunu[2274:c07] 

[{"id":"u581277341","command":"GET_USER_INFO","value":""}] 


2012-08-10 16:14:28.404 TaraftarlikOyunu[2274:c07] stream event 4 

2012-08-10 16:14:28.404 TaraftarlikOyunu[2274:c07] bytes 86 

    (lldb) 

maintenant je n'ai pas une idée que si elle tamponne ou non

======================= EDIT2 = ============= désolé à ce sujet. le problème apparaît probablement à cause de cette

(void)memcpy(buf, readBytes, len); 

Je viens de copier et coller cette partie du code. quel peut être le problème!

+0

Etes-vous sûr que vous devez envoyer JSON à une prise brute? Combinaison assez inhabituelle. – Farcaller

+0

ouais vous devriez faire une simple demande HTTP –

+0

Si votre nouveau à l'objectif C s'il vous plaît voir NSURLConnection et NSURLRequest. Ce que vous faites est adapté à la programmation de flux réseau qui est plus que nécessaire. –

Répondre

1

La méthode de connexion que vous utilisez est un peu trop.

Vous devez vous assurer que la connexion est arrivé au délégué

- (void)stream:(NSStream *)theStream handleEvent:(NSStreamEvent)streamEvent { 

switch (streamEvent) { 
    case NSStreamEventHasSpaceAvailable: 
     NSLog(@\"None!\"); 
     break; 
    case NSStreamEventOpenCompleted: 
     NSLog(@\"Stream opened\"); 
       //NOW you can write to the stream 
Questions connexes