我(显然)设法建立了一个ftp连接,但没有从中读取任何内容,并且有充分的理由:在连接超时之前我没有达到读数。
这是我的代码:
头:
NSInputStream *iStream;
NSOutputStream *oStream;
实现:
NSHost *host = [NSHost hostWithAddress:@"127.0.0.1"];
[iStream open]; // SOLUTION changes
[NSStream getStreamsToHost:host port:3333 inputStream:&iStream outputStream:&oStream];
NSMutableDictionary *settings = [NSMutableDictionary dictionaryWithCapacity:1];
[settings setObject:(NSString *)NSStreamSocketSecurityLevelTLSv1 forKey:(NSString *)kCFStreamSSLLevel];
[settings setObject:[NSNumber numberWithBool:YES] forKey:(NSString *)kCFStreamSSLAllowsAnyRoot];
[settings setObject:@"127.0.0.1" forKey:(NSString *)kCFStreamSSLPeerName];
/*[iStream retain];
[iStream setDelegate:self];
[iStream scheduleInRunLoop:[NSRunLoop currentRunLoop] forMode:NSDefaultRunLoopMode];
CFReadStreamSetProperty((CFReadStreamRef)iStream, kCFStreamPropertySSLSettings, (CFTypeRef)settings);
[iStream setProperty:NSStreamSocketSecurityLevelTLSv1 forKey:NSStreamSocketSecurityLevelKey];*/
//[iStream open]; SOLUTION changes: moved up
对于事件处理,我使用此功能,基于http://www.cocoadev.com/index.pl?NSStream:
- (void)stream:(NSStream *)aStream handleEvent:(NSStreamEvent)eventCode
{
if (aStream == iStream) {
[self handleInputStreamEvent:eventCode];
} else if (aStream == oStream) {
[self handleOutputStreamEvent:eventCode];
}
}
- (void)handleInputStreamEvent:(NSStreamEvent)eventCode
{
switch (eventCode) {
// SOLUTION changes: new inputstream handler
case NSStreamEventHasBytesAvailable:
if(!_data) {
_data = [[NSMutableData data] retain];
}
uint8_t buf[1024];
unsigned int len = 0;
len = [(NSInputStream *)iStream read:buf maxLength:1024];
if(len) {
[_data appendBytes:(const void *)buf length:len];
[bytesRead setIntValue:[bytesRead intValue]+len];
}
[self readBytes];
break;
case NSStreamEventOpenCompleted:
NSLog(@"NSStreamEventOpenCompleted");
break;
case NSStreamEventEndEncountered:
NSLog(@"NSStreamEventEndEncountered");
break;
case NSStreamEventErrorOccurred:
NSLog(@"An error occurred on the input stream.");
break;
}
}
我已经从这篇文章中省略了oStream设置以保持最小化。
我还没有向FTP发送请求以切换到ssl。
我非常感谢任何帮助,因为我发现Xcode对于调试来说非常可怕(没有异常或错误的步骤上的错误消息)。
答案 0 :(得分:0)
见Polling Versus Run-Loop Scheduling。请注意关键字与。
此外,我认为归咎于Xcode的调试功能是不公平的。 Xcode是IDE,可以很好地进行调试。当出现问题时,API应该引发异常(或返回nil),并且我在调试会话期间在objc_exception_throw()
或-[NSException raise]
上设置断点以捕获异常时从未遇到过问题。
需要考虑的另一点:你没有任何保护代码。这意味着您忽略了可能无法成功建立连接的可能性。错误检测的一部分是确保您自己的代码检测并处理故障,尤其是在涉及网络通信的情况下。