6

我想使用 GKSession 连接两台设备,一台作为服务器,另一台作为客户端。使用此配置我无法使用 GKPeerPickerController。

我在连接两个设备时遇到问题:

  • 仅使用蓝牙:不可能
  • 使用WiFi:至少设备之间有一些数据交换,但没有成功连接。

在接口文件中,我有

GKSessionDelegate
GKSession *session;

在实现中,我使用以下代码启动服务器:

session = [[GKSession alloc] initWithSessionID:@"iFood"  displayName:nil sessionMode:GKSessionModeClient];
session.delegate = self;
session.available = YES;

客户端开始使用此代码:

session = [[GKSession alloc] initWithSessionID:@"iFood"  displayName:nil sessionMode:GKSessionModeServer];
session.delegate = self;
session.available = YES;

如何强制使用蓝牙而不是 WiFi?

我也实现了这些调用:

-(void)session:(GKSession *)session didReceiveConnectionRequestFromPeer:(NSString *)peerID {
NSLog(@"Someone is trying to connect"); 
}

- (BOOL)acceptConnectionFromPeer:(NSString *)peerID error:(NSError **)error {
NSLog(@"acceptConnectionFromPeer");
}

当我开始时,我把它放到调试器中:

Listening on port 50775
2010-02-19 14:55:02.547 iFood[3009:5103] handleEvents started (2)

当另一个设备开始找到时,我得到了这个:

~ DNSServiceBrowse callback: Ref=187f70, Flags=2, IFIndex=2 (name=[en0]), ErrorType=0 name=00eGs1R1A..Only by Audi regtype=_2c3mugr67ej6j7._udp. domain=local.
~ DNSServiceQueryRecord callback: Ref=17bd40, Flags=2, IFIndex=2 (name=[en0]), ErrorType=0 fullname=00eGs1R1A\.\.Only\032by\032Audi._2c3mugr67ej6j7._udp.local. rrtype=16 rrclass=1 rdlen=18 ttl=4500
** peer 1527211048: oldbusy=0, newbusy=0
~ DNSServiceBrowse callback: Ref=187f70, Flags=2, IFIndex=-3 (name=[]), ErrorType=0 name=00eGs1R1A..Only by Audi regtype=_2c3mugr67ej6j7._udp. domain=local.
GKPeer[186960] 1527211048 service count old=1 new=2
~ DNSServiceQueryRecord callback: Ref=17bd40, Flags=2, IFIndex=-3 (name=[]), ErrorType=0 fullname=00egs1r1a\.\.only\032by\032audi._2c3mugr67ej6j7._udp.local. rrtype=16 rrclass=1 rdlen=18 ttl=7200
** peer 1527211048: oldbusy=0, newbusy=0
~ DNSServiceBrowse callback: Ref=187f70, Flags=2, IFIndex=-3 (name=[]), ErrorType=0 name=00TF5kc1A..Only by Audi regtype=_2c3mugr67ej6j7._udp. domain=local.
~ DNSServiceQueryRecord callback: Ref=188320, Flags=2, IFIndex=-3 (name=[]), ErrorType=0 fullname=00tf5kc1a\.\.only\032by\032audi._2c3mugr67ej6j7._udp.local. rrtype=16 rrclass=1 rdlen=18 ttl=7200
** peer 1723356125: oldbusy=0, newbusy=0
~ DNSServiceQueryRecord callback: Ref=188320, Flags=2, IFIndex=2 (name=[en0]), ErrorType=0 fullname=00TF5kc1A\.\.Only\032by\032Audi._2c3mugr67ej6j7._udp.local. rrtype=16 rrclass=1 rdlen=18 ttl=4500
** peer 1723356125: oldbusy=0, newbusy=0

我在这里缺少什么?

我确定两个设备都启用了蓝牙并连接到同一个 WiFi。

谢谢,

河。

4

2 回答 2

1

我认为您错过了接受与客户的联系。收到“didReceiveConnectionRequestFromPeer”回调后,您需要接受与客户端的连接,如下所示:

-(void)session:(GKSession *)session didReceiveConnectionRequestFromPeer:(NSString *)peerID {
  NSLog(@"Someone is trying to connect"); 
  NSError *error;
  [gkSession acceptConnectionFromPeer:peerID error:&error];
  if(error)
    NSLog(@"Error on accept connection with peer: ", error);
}

在此之后,您将在此处收到“GKPeerStateConnected”:

- (void)session:(GKSession *)session peer:(NSString *)peerID didChangeState:(GKPeerConnectionState)state{}

我希望这对你有帮助。

于 2013-01-07T14:12:58.403 回答
-1

我有类似的问题,但从上面的描述我认为你犯了一些错误:

GKSession 只实现BT;如果您使用选择器,那么您可以提供单独的方法来处理 WiFi 连接。

“didReceiveConnectionRequestFromPeer”方法应该在会话对象上调用“acceptConnectionFromPeer”方法——您没有在您的委托上实现“acceptConnectionFromPeer”。

对于调试,您应该在委托方法“session:peer:didChangeState:”中记录状态更改(请参阅http://developer.apple.com/iPhone/library/documentation/GameKit/Reference/GKSessionDelegate_Protocol/Reference/Reference.html) . 当对等点“可用”时,可以调用“connectToPeer:”;当“已连接”时,您可以使用“sendData:toPeers:”。

对于建立连接后的 IO,您希望在会话上调用“setDataReceiveHandler:withContext:”方法。

早些时候我的代码中有一些拼写错误,但现在可以正常工作了。

祝你好运。

于 2010-02-21T07:33:52.257 回答