У меня есть приложение для iPhone, которое я запускаю на симуляторе.XCode ver 3.2.6 / 4.3.Я пытаюсь связаться с радио через последовательный порт ПК через Wi-Fi, как на одном сервере ... Я пробовал NSStream и GCDAsyncSocket (просто чтобы убедиться).Радио имеет свой собственный IP-адрес и номер порта.Это на самом деле модуль Wi-Fi TCP / IP.После изменения удаленного доступа на ПК, чтобы он принимал мой IP-адрес, я, наконец, смог подключиться, но меня сразу же отключили, я предполагаю, что это когда я пытаюсь читать или писать.То же самое происходит при использовании Telnet, подключается, затем отключается.Радиостанция выдает HELLO , когда кто-то подключается, поэтому Telnet должен попытаться прочитать, так как данные отправлены.Я догадываюсь.Я думал, так как я могу подключиться, я должен быть в состоянии читать / писать.(Да, новичок здесь)
Буду признателен за любые мысли или указания.Я изучаю уже более недели и собираюсь помешаться.
Спасибо.Я добавил приведенный ниже код и сообщение об ошибке.
Это сообщение об ошибке: socketDidDisconnect: withError: "Ошибка домена = NSOSStatusErrorDomain Code = -9844" Операция не может быть завершена.(Ошибка OSStatus -9844.) "UserInfo = 0x4c38a60 {}"
- (IBAction)performConnection:(id)sender
{
asyncSocket = [[GCDAsyncSocket alloc] initWithDelegate:self delegateQueue:dispatch_get_main_queue()];
NSError *error = nil;
uint16_t port = [[[self serverPort] text] intValue];
if (![asyncSocket connectToHost:[serverAddr text] onPort:port error:&error])
{
DDLogError(@"Unable to connect due to invalid configuration: %@", error);
[self debugPrint:[NSString stringWithFormat:@"Unable to connect due to invalid configuration: %@", error]];
}
else
{
DDLogVerbose(@"Connecting...IP:%@, port:%i", [serverAddr text], port);
}
}
- (void)socket:(GCDAsyncSocket *)sock didConnectToHost:(NSString *)host port:(UInt16)port
{
DDLogInfo(@"socket:%p didConnectToHost:%@ port:%hu", sock, host, port);
NSMutableDictionary *settings = [NSMutableDictionary dictionaryWithCapacity:3];
[settings setObject:@"XXX.XXX.X.XXX"
forKey:(NSString *)kCFStreamSSLPeerName];
// In fact, don't even validate the certificate chain
[settings setObject:[NSNumber numberWithBool:NO]
forKey:(NSString *)kCFStreamSSLValidatesCertificateChain];
[settings setObject:(NSString*)kCFStreamPropertySocketSecurityLevel
forKey:(NSString*)kCFStreamSocketSecurityLevelNegotiatedSSL];
DDLogVerbose(@"Starting TLS with settings:\n%@", settings);
[sock startTLS:settings];
[self debugPrint:[NSString stringWithFormat:@"socket:didConnectToHost:%@ port:%hu", host, port]];
//[sock readDataToData:[GCDAsyncSocket CRLFData] withTimeout:-1 tag:0];
[sock readDataWithTimeout:-1 tag:0];
}
- (void)socket:(GCDAsyncSocket *)sock didWriteDataWithTag:(long)tag
{
DDLogVerbose(@"socket:didWriteDataWithTag:");
[sock readDataWithTimeout:-1 tag:0];
}
- (void)socket:(GCDAsyncSocket *)sock didReadData:(NSData *)data withTag:(long)tag
{
DDLogVerbose(@"socket:didReadData:withTag:");
NSString *response = [[NSString alloc] initWithData:data encoding:NSASCIIStringEncoding];
NSLog(@"read response:%@", response);
[self debugPrint:[NSString stringWithFormat:@"Read: \n%@",response]];
[response release];
//NSData *newline = [@"\n" dataUsingEncoding:NSASCIIStringEncoding];
//[sock readDataToData:newline withTimeout:-1 tag: 0];
[sock readDataWithTimeout:-1 tag:0];
}
- (IBAction)sendBuf:(id)sender
{
if ([[bufOut text] length] > 0)
{
NSString *requestStr = [NSString stringWithFormat:@"%@\r\n", [bufOut text]];
NSLog(@"Sending:%@",requestStr);
NSData *requestData = [requestStr dataUsingEncoding:NSASCIIStringEncoding];
[asyncSocket writeData:requestData withTimeout:-1.0 tag:0];
[self debugPrint:[NSString stringWithFormat:@"Sent: \n%@",requestStr]];
}
}