AsyncUdpSocketを使用して、SSDPディスカバリーを実行し、コントローラーを検索しました。これが私のコードスニペットです:
ソケットを初期化してセットアップします。
// AsyncUdpSocket *ssdpSock = [[AsyncUdpSocket alloc] initWithDelegate:self];
AsyncUdpSocket *ssdpSock = [[AsyncUdpSocket alloc] initIPv4];
[ssdpSock setDelegate:self];
コメントアウトされた最初の行に注意してください。AsyncUdpSocketフォーラムで、重複に関するいくつかの問題を見つけました。私は彼らに直面していたとは思いませんが、とにかくそれをしました。
エラーチェックを追加しました。デバッグ中にソケットを閉じていなかったため、ソケットのセットアップに失敗し始めたので便利でした。
NSError *socketError = nil;
if (![ssdpSock bindToPort:1900 error:&socketError]) {
NSLog(@"Failed binding socket: %@", [socketError localizedDescription]);
return statusController;
}
if(![ssdpSock joinMulticastGroup:@"239.255.255.250" error:&socketError]){
NSLog(@"Failed joining multicast group: %@", [socketError localizedDescription]);
return statusController;
}
if (![ssdpSock enableBroadcast:TRUE error:&socketError]){
NSLog(@"Failed enabling broadcast: %@", [socketError localizedDescription]);
return statusController;
}
[ssdpSock sendData:[self.discoverControllerString dataUsingEncoding:NSUTF8StringEncoding]
toHost:@"239.255.255.250"
port:1900
withTimeout:2
tag:1];
タイムアウトに加えた変更に注意してください。そして最後に受信セットアップを行い、ソケットを閉じました。ソケットが閉じていることに注意してください。これを実行しているときは自分のクラスにいるので、上記のコードは機能しませんでした。
[ssdpSock receiveWithTimeout: 2 tag:1];
[NSTimer scheduledTimerWithTimeInterval: 5 target: self
selector:@selector(completeSearch:) userInfo: self repeats: NO];
[ssdpSock closeAfterSendingAndReceiving];
最も重要な変更は、コントローラーが見つからなかった場合に「NO」を返すことでした。最初の受信は、偶然にも発見メッセージ自体が戻ってきたことでした。また、AsyncUdpSocket.hファイルを注意深く読んだ場合、探しているパケットでない場合は「NO」が返されます。
また、コードでARCを使用していますが、ARCをサポートせずにAsyncUdpSocketをコンパイルしたことにも注意してください。
-(void) completeSearch: (NSTimer *)t
{
NSLog(@"%s",__FUNCTION__);
//[ssdpSock close];
//ssdpSock = nil;
}
- (BOOL)onUdpSocket:(AsyncUdpSocket *)sock
didReceiveData:(NSData *)data
withTag:(long)tag
fromHost:(NSString *)host
port:(UInt16)port
{
NSLog(@"%s %ld %@ %d",__FUNCTION__,tag,host,port);
NSString *aStr = [[NSString alloc] initWithData:data encoding:NSASCIIStringEncoding];
NSLog(@"%@",aStr);
NSString *compareString = [aStr stringByPaddingToLength:[self.responseString length] withString:@"." startingAtIndex:0];
//NSLog(@"%@", compareString);
//NSLog(@"%@", self.responseString);
if ([compareString isEqualToString:self.responseString])
{
NSLog(@"String Compare, Controller Found!");
[self.controllerList addObject:aStr];
//NSData *controllerIP = [aStr dataUsingEncoding:NSUTF8StringEncoding];
[[NSNotificationCenter defaultCenter] postNotificationName:@"DiscoveredController" object:nil];
return YES;
}
return NO;
}