android - 当我作为客户端连接时,为什么客户端列表为空?

标签 android android-wifi p2p wifi-direct wifip2p

我正在使用 Android Wi-Fi Direct 服务发现。当连接信息可用时,如果形成了组,我会请求组信息。由于某种原因,当我作为客户端连接时,我可以从组中获取组所有者,但客户端列表为空。当我以群组所有者身份连接时,我能够获取群组所有者和客户端列表。当我进入聊天 fragment 时,我试图显示群组所有者和客户是谁。另一个问题是组所有者设备名称似乎为空,但其余信息是正确的,例如地址(我删除了地址行)。我尝试在几个不同的地方请求组信息,但作为客户端连接时我永远无法获取客户端列表。当我收到 SERVICE_CONNECTED Intent 时,我会切换到聊天 fragment 。

作为客户端连接:

I/wfd_: Wi-Fi P2P Connection Changed
I/wfd_: Connected to P2P network. Requesting connection info
I/wfd_: Connection info available
I/wfd_: WifiP2pInfo: 
I/wfd_: Group formed: true
        Is group owner: false
        Group owner address: /192.168.49.1
I/wfd_: Stopping service discovery
I/wfd_: Service discovery stopped
I/wfd_: Connected as client
I/wfd_: Requesting group info
I/wfd_CommReceiver: This device changed
I/wfd_ClientSocketHandler: Client socket thread running
I/wfd_ClientSocketHandler: Opening client socket
I/System.out: [CDS][DNS] getAllByNameImpl netId = 0
I/System.out: [socket][0] connection /192.168.49.1:4545;LocalPort=34789(5000)
I/System.out: [CDS]connect[/192.168.49.1:4545] tm:5
I/wfd_: Service discovery requests cleared
I/wfd_: Group info available
I/wfd_: WifiP2pGroup:
I/wfd_: Network name: DIRECT-Ig-BLU Clark 2
        Is group owner: false
        Group owner: 
        Device name: BLU Clark 2
        Status: Unavailable

        Client list is empty.
/System.out: [socket][/192.168.49.117:34789] connected
I/wfd_ClientSocketHandler: Client socket - true
I/wfd_ClientSocketHandler: Launching the I/O handler
I/wfd_CommReceiver: Service connected
I/wfd_CommReceiver: Switching to Chat fragment
I/wfd_: handleMessage() called

以群组所有者身份连接:

I/wfd_: Wi-Fi P2P Connection Changed
I/wfd_: Connected to P2P network. Requesting connection info
I/wfd_: Connection info available
I/wfd_: WifiP2pInfo: 
I/wfd_: Group formed: true
        Is group owner: true
        Group owner address: /192.168.49.1
I/wfd_: Stopping service discovery
I/wfd_: Service discovery stopped
I/wfd_: Connected as group owner
I/wfd_OwnerSocketHandler: Group owner server socket started
I/wfd_: Requesting group info
I/wfd_OwnerSocketHandler: Group owner server socket thread running
I/wfd_: Service discovery requests cleared
I/wfd_CommReceiver: This device changed
I/wfd_: Group info available
I/wfd_: WifiP2pGroup:
I/wfd_: Network name: DIRECT-XB-Brendan BLU
        Is group owner: true
        Group owner: 
        Device name: 
        Status: Unavailable

        Client: 
        Device name: BLU Clark 2
        Status: Connected
I/wfd_CommReceiver: Service connected
I/wfd_CommReceiver: Switching to Chat fragment
I/wfd_OwnerSocketHandler: Launching the I/O handler
I/wfd_: handleMessage() called

代码:

@Override
    public void onConnectionInfoAvailable(WifiP2pInfo wifiP2pInfo) {
        Log.i(TAG, "Connection info available");

        Log.i(TAG, "WifiP2pInfo: ");
        Log.i(TAG, p2pInfoToString(wifiP2pInfo));
        this.groupFormed = wifiP2pInfo.groupFormed;
        this.isGroupOwner = wifiP2pInfo.isGroupOwner;

        if (wifiP2pInfo.groupFormed) {
            stopServiceDiscovery();

            Thread handler;
            if (wifiP2pInfo.isGroupOwner) {
                Log.i(TAG, "Connected as group owner");
                try {
                    handler = new OwnerSocketHandler(this.getHandler());
                    handler.start();
                } catch (IOException e) {
                    Log.e(TAG, "Failed to create a server thread - " + e.getMessage());
                    return;
                }
            } else {
                Log.i(TAG, "Connected as client");
                handler = new ClientSocketHandler(this.getHandler(), wifiP2pInfo.groupOwnerAddress);
                handler.start();
            }

            Log.i(TAG, "Requesting group info");
            // Requests peer-to-peer group information
            wifiP2pManager.requestGroupInfo(channel, new WifiP2pManager.GroupInfoListener() {
                @Override
                public void onGroupInfoAvailable(WifiP2pGroup wifiP2pGroup) {
                    Log.i(TAG, "Group info available");
                    if (wifiP2pGroup != null) {
                        Log.i(TAG, "WifiP2pGroup:");
                        Log.i(TAG, p2pGroupToString(wifiP2pGroup));
                        WifiDirectHandler.this.wifiP2pGroup = wifiP2pGroup;
                    } else {
                        Log.w(TAG, "Group is null");
                    }
                    localBroadcastManager.sendBroadcast(new Intent(Action.SERVICE_CONNECTED));
                }
            });

        } else {
            Log.w(TAG, "Group not formed");
        }
        localBroadcastManager.sendBroadcast(new Intent(Action.DEVICE_CHANGED));
    }

最佳答案

根据 Wi-Fi Direct 贡献者之一的说法,组客户端无法看到其他客户端的列表。群组所有者必须跟踪这一情况并通知群组客户。

https://groups.google.com/forum/#!topic/wi-fi-direct/Ox83PKa1ilw

关于android - 当我作为客户端连接时,为什么客户端列表为空?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38187617/

相关文章:

java - tensorflow float32的转换与java对象不兼容

android - 如何在android中创建自己的wifi热点

Android,连接到wifi网络时如何覆盖互联网连接检查?

android - Wifi 热点组播/广播

Java ME,如何实现点对点通信?

java - 如何获取库的所有依赖项?

android - 用退格键删除整个 Spannable

java - Android 中的单例与应用程序上下文?

javascript - 如何在没有Flash/Java的情况下实现浏览器到浏览器的通信(允许服务器作为桥梁)?

android - 3G 中的 NAT 是如何工作的