Android 6(Marshmallow)Wifi +蓝牙有时会导致SocketTimeoutException

Tom*_*Dev 3 android bluetooth socket-timeout-exception ibeacon-android android-6.0-marshmallow

当用户当前正在使用该应用时,我们的Android应用会出现问题,该应用会使用蓝牙扫描信标.应用程序在加载不同视图时从API加载数据.有时,当继续单击视图时,一个请求失败(超时),出现此错误:

java.net.SocketTimeoutException: failed to connect to www.examplehost.com/111.222.333.444 (port 80) after 15000ms
                                              at libcore.io.IoBridge.connectErrno(IoBridge.java:169)
                                              at libcore.io.IoBridge.connect(IoBridge.java:122)
                                              at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:183)
                                              at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:452)
                                              at java.net.Socket.connect(Socket.java:884)
                                              at com.android.okhttp.internal.Platform.connectSocket(Platform.java:117)
                                              at com.android.okhttp.internal.http.SocketConnector.connectRawSocket(SocketConnector.java:434)
                                              at com.android.okhttp.internal.http.SocketConnector.connectCleartext(SocketConnector.java:105)
                                              at com.android.okhttp.Connection.connect(Connection.java:1331)
                                              at com.android.okhttp.Connection.connectAndSetOwner(Connection.java:1410)
                                              at com.android.okhttp.OkHttpClient$1.connectAndSetOwner(OkHttpClient.java:128)
                                              at com.android.okhttp.internal.http.HttpEngine.nextConnection(HttpEngine.java:466)
                                              at com.android.okhttp.internal.http.HttpEngine.connect(HttpEngine.java:447)
                                              at com.android.okhttp.internal.http.HttpEngine.sendRequest(HttpEngine.java:353)
                                              at com.android.okhttp.internal.huc.HttpURLConnectionImpl.execute(HttpURLConnectionImpl.java:468)
                                              at com.android.okhttp.internal.huc.HttpURLConnectionImpl.getResponse(HttpURLConnectionImpl.java:410)
                                              at com.android.okhttp.internal.huc.HttpURLConnectionImpl.getResponseCode(HttpURLConnectionImpl.java:532)
Run Code Online (Sandbox Code Playgroud)

(这是我们服务器的IP地址,替换为111.222.333.444)

这是一个超时(> 15秒),而之前的请求相当快.

我没有遇到其他设备的这个问题,只有在更新到Android 6.0.1时才能在Samsung S6上使用.因为应用程序位于前台,我认为它不是Doze或Standby(Android 6中的新功能),因为该应用程序正在被积极使用.但是当应用程序处于后台时可能会出现同样的问题(但很难测试).

有没有人知道我们应该在哪里寻找问题?提前致谢.

dav*_*ung 5

虽然这是我在S6上听到的第一个报告,但这是 Nexus 4,Nexus 7,Moto G和Moto X等其他设备上的常见问题.这些设备会遇到WiFi和蓝牙无线电之间的干扰,它们共享相同的无线电频带和一些设备型号共用一个芯片和天线.在Nexus 4和Moto G上,问题是如此糟糕,以至于在使用蓝牙扬声器时流式传输音乐是不可能的.所以这个问题并不是特定于信标的.

没有已知的解决方法,但您可以检测设备型号,如果已知有问题,则提示用户关闭WiFi.甚至为用户做这件事(当然有正确的通知.)

知道在具有早期Android版本的S6上是否存在相同的问题会很有趣.如果是这样,这表明至少可以在固件中对S6进行修复.

完全披露:我是Android Beacon Library开源项目的首席开发人员.