作成中の iPhone アプリケーションに問題があります。アプリは JSON 要求を Python サーバーに送信し、サーバーから JSON 応答を読み取ります。サーバーにデータを送信し、応答を取得して NSData に入れる次の関数があります。(投稿用のサーバーアドレスを取り出しました)
+(NSData *)accessServer:(NSMutableDictionary *) dic needResponse:(BOOL) response
{
// Conect to the server
CFReadStreamRef readStream;
CFWriteStreamRef writeStream;
CFStringRef remoteHost = CFSTR("");
CFStreamCreatePairWithSocketToHost(NULL, remoteHost, 5687, &readStream, &writeStream);
CFWriteStreamOpen(writeStream);
CFReadStreamOpen(readStream);
// send data
NSData *json = [NSJSONSerialization dataWithJSONObject:dic options:0 error:nil];
NSString *jsonString = [[NSString alloc]initWithData:json encoding:NSUTF8StringEncoding];
jsonString = [NSString stringWithFormat:@"%@%@", jsonString, @"\r\n\r\n"];
UInt8 *writeBuf = (UInt8 *)[jsonString UTF8String];
int writtenBytes = 0;
int bytesToSend = (int)[jsonString lengthOfBytesUsingEncoding:NSUTF8StringEncoding];
while(writtenBytes < bytesToSend)
{
writtenBytes += CFWriteStreamWrite(writeStream, writeBuf, bytesToSend-writtenBytes);
}
NSLog(@"Done sending, Sent :%d Total: %d",writtenBytes,bytesToSend);
CFWriteStreamClose(writeStream);
if(response)
{
// get the return data
uint8_t readData[10000];
int readBytes = 1;
int totalRead = 0;
while(readBytes > 0)
{
readBytes = (int)CFReadStreamRead(readStream, readData, 10000);
totalRead += readBytes;
}
CFReadStreamClose(readStream);
return [[NSData alloc]initWithBytes:readData length:totalRead];
}
else
{
CFReadStreamClose(readStream);
return nil;
}
}
問題は、NSData を取得して NSString に変換しようとしたときに、長さが 0 であり、NSData の長さが 0 より大きいことです。次のコードは、NSData を取得して NSString に変換する方法です。
NSData *t = [Globals accessServer:getLocationData needResponse:TRUE];
NSString *tempString = [[NSString alloc]initWithData:t encoding:NSUTF8StringEncoding];
この問題は、約 10% の確率で発生するようです。1 時間も起こらないこともあれば、10 回連続で起こることもあります。これ以上の情報が必要な場合はお知らせください。