Android 物联网socket通信采坑
程序员文章站
2022-03-23 22:02:02
1.背景本身要实现一个简单的物联网App,硬件设备开启局域网wifi,手机连接WIFI后进行TCP通信,但就这么简单的应用却遇到坑了,在这里记录一下;2.问题在测试硬件设备串口WIFI功能时遇到了奇怪的现象,在上图中设备以AP模式开启Wifi,客户端设备断开其他网络通道(手机关闭数据流量、PC拔掉网线)后连接此wifi,结果除PC端连接正常外,移动设备(ios与Android)都出现了TCP连接失败,ios端可以ping通192.168.8.0;查看Socket连接报错日志如下:java.ne...
1.背景
本身要实现一个简单的物联网App,硬件设备开启局域网wifi,手机连接WIFI后进行TCP通信,但就这么简单的应用却遇到坑了,在这里记录一下;
2.问题
在测试硬件设备串口WIFI功能时遇到了奇怪的现象,在上图中设备以AP模式开启Wifi,客户端设备断开其他网络通道(手机关闭数据流量、PC拔掉网线)后连接此wifi,结果除PC端连接正常外,移动设备(ios与Android)都出现了TCP连接失败,ios端可以ping通192.168.8.0;
查看Socket连接报错日志如下:
java.net.ConnectException: failed to connect to /192.168.8.0 (port 8080) from /:: (port 0): connect failed: ENETUNREACH (Network is unreachable)
at libcore.io.IoBridge.connect(IoBridge.java:143)
at java.net.PlainSocketImpl.socketConnect(PlainSocketImpl.java:142)
at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:390)
at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:230)
at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:212)
at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:436)
at java.net.Socket.connect(Socket.java:621)
at java.net.Socket.connect(Socket.java:570)
at java.net.Socket.<init>(Socket.java:450)
at java.net.Socket.<init>(Socket.java:218)
at top.luchenxi.lgrswifitest.TcpClient.run(TcpClient.java:60)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1167)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:641)
at java.lang.Thread.run(Thread.java:919)
Caused by: android.system.ErrnoException: connect failed: ENETUNREACH (Network is unreachable)
at libcore.io.Linux.connect(Native Method)
at libcore.io.ForwardingOs.connect(ForwardingOs.java:95)
at libcore.io.BlockGuardOs.connect(BlockGuardOs.java:136)
at libcore.io.ForwardingOs.connect(ForwardingOs.java:95)
at libcore.io.IoBridge.connectErrno(IoBridge.java:157)
at libcore.io.IoBridge.connect(IoBridge.java:135)
... 13 more
connect failed: ENETUNREACH (Network is unreachable),而并非是 ETIMEDOUT
尝试在以上连接下,局域网内各客户端进行通信,出现如下情况:
由于对网络知识的匮乏,经过好几天的无脑尝试(更换测试工具、更换测试手机品牌、客户端配置固定IP、配置网关、配置DNS、联系串口wifi供应商等),最后尝试修改设备串口wifi模块服务IP后,居然…神奇的解决了!!!!!!
改动如下:
将服务器IP:192.168.8.0 修改为 192.168.8.1
3.原因
大概原因为192.168.8.0/24 与 192.168.8.255/24这个两个地址比较特殊,百度上有种说法是一个为域地址一个为广播地址,这两个地址并不在192.168.8.0/24这个网段中。
但是如果不在一个网段中,为什么PC端能够连接呢?
有大佬指导原因的话麻烦指导下!!不胜感激!!
本文地址:https://blog.csdn.net/fh_luchenxi/article/details/108583763
上一篇: Java基础-数据结构