CFStream + SSL приводит к ошибке OSStatus -108 - PullRequest
4 голосов
/ 27 апреля 2011

У меня есть код, который создает пару объектов CFStream на удаленном сервере с включенной SSL / TLS . Этот код прекрасно работает на OS X, но при запуске под iOS не работает. Вот журнал консоли:

2011-04-26 22:39:35.820 RemoteSample[92127:40b] connecting to 192.168.1.187:8099
2011-04-26 22:39:35.825 RemoteSample[92127:40b] INPUT: NSStreamEventOpenCompleted
2011-04-26 22:39:35.825 RemoteSample[92127:40b] OUTPUT: NSStreamEventOpenCompleted
2011-04-26 22:39:35.827 RemoteSample[92127:40b] INPUT: NSStreamEventErrorOccurred
2011-04-26 22:39:35.828 RemoteSample[92127:40b] Error on input stream: The operation couldn’t be completed. (OSStatus error -108.)
2011-04-26 22:39:35.829 RemoteSample[92127:40b] OUTPUT: NSStreamEventErrorOccurred
2011-04-26 22:39:35.829 RemoteSample[92127:40b] Error on output stream: The operation couldn’t be completed. (OSStatus error -108.)

Ошибка OSStatus -108 выглядит как memFullErr, что просто странно, и я не совсем уверен, что с этим делать. Это происходит как в симуляторе, так и на устройстве. Он компилируется и работает без этой проблемы в приложении Mac OS X. Эта ошибка возникает только при сборке для iOS.

Потратив несколько часов, пробуя различные идеи и много разыскивая, я мог бы воспользоваться некоторыми советами о следующих шагах.

Вот код:

CFReadStreamRef inCfStream = NULL;
CFWriteStreamRef outCfStream = NULL;
CFStreamCreatePairWithSocketToHost(NULL, (CFStringRef)host, port, &inCfStream, &outCfStream);
if (inCfStream && outCfStream)
{
    CFReadStreamSetProperty(inCfStream, kCFStreamPropertyShouldCloseNativeSocket, kCFBooleanTrue);

    inStream = NSMakeCollectable(inCfStream);
    outStream = NSMakeCollectable(outCfStream);
    [inStream setDelegate:self];
    [outStream setDelegate:self];
    [inStream scheduleInRunLoop:[NSRunLoop currentRunLoop] forMode:NSDefaultRunLoopMode];
    [outStream scheduleInRunLoop:[NSRunLoop currentRunLoop] forMode:NSDefaultRunLoopMode];
    [inStream setProperty:NSStreamSocketSecurityLevelNegotiatedSSL forKey:NSStreamSocketSecurityLevelKey];

    NSDictionary *properties = [NSDictionary dictionaryWithObjectsAndKeys:
                                [NSNumber numberWithBool:YES], kCFStreamSSLAllowsExpiredCertificates,
                                [NSNumber numberWithBool:YES], kCFStreamSSLAllowsAnyRoot,
                                [NSNumber numberWithBool:NO], kCFStreamSSLValidatesCertificateChain,
                                kCFNull,kCFStreamSSLPeerName,
                                nil];
    if (CFReadStreamSetProperty(inCfStream, kCFStreamPropertySSLSettings, (CFTypeRef)properties) == FALSE)
    {
        NSLog(@"Failed to set SSL properties on read stream.");
    }

    inputBuffer = [[NSMutableData alloc] init];
    [inStream open];
    [outStream open];
}
...