移动端webscoket连接失败—code1006
问题
最近开发一款移动端app,使用原生webscoket与服务器进行实时通信,在调试过程中出现的问题,ios版本和小米平板当中都可以连接触成功并进行通信,但在小米手机(红米10x)、华为平板却连接失败,无法连接上,出现报错 WebSocket connection to ‘*’ failed: Error in connection establishment: net::ERR_NAME_NOT_RESOLVED
(图是网上找的)
分析原因
将webscoket的onclose打印出来,发现提示code 1006。查了文档说明,1006为:用于期望收到状态码时连接非正常关闭 (也就是说, 没有发送关闭帧).,我的理解是既不是服务器主动断开连接,也不是客户端主动断开连接。而且这个出现在部分设备中(其他设备好好的)。后来才发现设备阻止了webscoket的连接,原因是我采用的是ws请求而不是wss,ws相当于http(这个我就不细说),很多移动端设备处于网络安全禁止设置使用http。所以这就是问题所在。
解决的办法
解决的办法我也是参考网上的,毕竟我只是小小的前端,对app开发了解不是很深入。
更改网络安全配置
1.在res文件夹下创建一个xml文件夹,然后创建一个network_security_config.xml文件,文件内容如下
<?xml version="1.0" encoding="utf-8"?>
<network-security-config>
<base-config cleartextTrafficPermitted="true" />
</network-security-config>
2.接着,在AndroidManifest.xml文件下的application标签增加以下属性:
<application
...
android:networkSecurityConfig="@xml/network_security_config"
...
/>
这样就可以了。