我正在尝试使用CFStream进行简单的超文本传输协议通信,但是使用下面的代码,即使我给出了一个无效的URL (wwwww.yahoo.com),我仍然可以成功地连接。
有人能告诉我这段代码出了什么问题吗?我预计对CFReadStreamOpen()的调用会失败,但即使URL不正确,它也会成功。
我还没有找到一个简单的CFNetwork示例,它可以在ARC上工作的HTTP (不使用NSURL)。如果有人知道这样的示例代码,请让我知道。
- (void) test
{
CFStringRef m_host = CFStringCreateWithCString(NULL, "wwwww.yahoo.com", kCFStringEncodingASCII);
int m_port = 80;
CFHostRef host;
NSLog(@"Attempting to (re)connect to %@:%d", m_host, m_port);
{
CFReadStreamRef m_in = NULL;
CFWriteStreamRef m_out = NULL;
host = CFHostCreateWithName(kCFAllocatorDefault, (CFStringRef)m_host);
if (!host)
{
NSLog(@"Error resolving host %@", m_host);
}
CFStreamCreatePairWithSocketToCFHost(kCFAllocatorDefault, host , m_port, &m_in, &m_out);
CFRelease(host);
CFStreamClientContext context = {0, nil,nil,nil,nil};
if (CFReadStreamSetClient(m_in, kCFStreamEventHasBytesAvailable | kCFStreamEventErrorOccurred | kCFStreamEventEndEncountered, networkReadEvent, &context))
{
CFReadStreamScheduleWithRunLoop(m_in, CFRunLoopGetCurrent(),kCFRunLoopCommonModes);
}
if (CFWriteStreamSetClient(m_out, kCFStreamEventErrorOccurred | kCFStreamEventEndEncountered, networkWriteEvent, &context))
{
CFWriteStreamScheduleWithRunLoop(m_out, CFRunLoopGe tCurrent(),kCFRunLoopCommonModes);
}
BOOL success = CFReadStreamOpen(m_in);
CFErrorRef error = CFReadStreamCopyError(m_in);
if (!success || (error && CFErrorGetCode(error) != 0))
{
NSLog(@"Connect error %s : %ld", CFErrorGetDomain(error), CFErrorGetCode(error));
[NSThread sleepForTimeInterval:5.0];
}
success = CFWriteStreamOpen(m_out);
error = CFReadStreamCopyError(m_in);
if (!success || (error && CFErrorGetCode(error) != 0))
{
NSLog(@"Connect error %s : %d", CFErrorGetDomain(error), CFErrorGetCode(error));
[NSThread sleepForTimeInterval:5.0];
}
else
{
NSLog(@"Connected");
}
}
}发布于 2014-10-24 13:48:14
对于像您这样的异步代码,您需要设置委托并捕获那里的错误。查看http://iphonedevsdk.com/forum/iphone-sdk-development/17542-cfstream-catch-error-in-connection.html
根据Apple Developer站点,“如果流可以在后台打开而不阻塞,则此函数总是返回true。”这意味着打开流的请求是在不同的线程上发出的,因此当您调用该函数并在后台线程上启动连接进程时,该函数将返回true。然后,各个流上的所有读/写调用都会被阻塞,直到后台线程完成打开流为止。如果您在"CFReadStreamOpen(m_in);“上设置了一个断点,您将能够看到这一点,并查看在执行这一行之后会发生什么。希望这能回答你的问题。
https://stackoverflow.com/questions/11459452
复制相似问题