1# HiSpark WiFi-IoT 套件样例开发--网络编程(tcpserver) 2 3![hihope_illustration](https://gitee.com/hihopeorg/hispark-hm-pegasus/raw/master/docs/figures/hihope_illustration.png) 4 5[HiSpark WiFi-IoT开发套件](https://item.taobao.com/item.htm?spm=a1z10.1-c-s.w5003-23341819265.1.bf644a82Da9PZK&id=622343426064&scene=taobao_shop) 首发于HDC 2020,是首批支持OpenHarmony 2.0的开发套件,亦是官方推荐套件,由润和软件HiHope量身打造,已在OpenHarmony社区和广大OpenHarmony开发者中得到广泛应用。 6 7![wifi_iot](https://gitee.com/hihopeorg/hispark-hm-pegasus/raw/master/docs/figures/2.png) 8 9## netcat简介 10 11### netcat 是什么? 12 13netcat是一个非常强大的网络实用工具,可以用它来调试TCP/UDP应用程序; 14 15### netcat 如何安装? 16 17Linux上可以使用发行版的包管理器安装,例如Debian/Ubuntu上: 18 19* `sudo apt-get install netcat` 20 21Windows上,MobaXterm工具上也可以用 `apt-get install netcat` 安装; 22 23### netcat 如何使用? 24 25开始之前,先简单介绍一下 netcat 的几种用法: 26 271. TCP服务端模式: `netcat -l 5678` ,会启动一个TCP服务器,监听`5678`端口,你可以换成其他端口; 282. TCP客户端模式: `netcat localhost 5678`, `localhost`是目标主机参数,可以换成其他你想要连接的主机(主机名、IP地址、域名都可以),`5678`是端口; 29 * 你如果在同一台机器的两个终端中分别执行上述两条命令,它们两者之间就会建立连接一条TCP连接,此时你在其中一个终端上输入字符,敲回车就会发送到另一个终端中; 303. UDP服务端模式: `netcat -u -l 6789`, 没错,只需要加一个`-u`参数,就可以启动一个UDP服务端; 314. UDP客户端模式: `netcat -u localhost 6789`, 32 * 类似的,在同一台机器的两个终端中分别执行上述两条命令,他们两者之间也可以收发消息,只不过是UDP报文; 33 34 35 36 37## LwIP简介 38 39### LwIP是什么? 40 41> A Lightweight TCP/IP stack 42> 一个轻量级的TCP/IP协议栈 43 44详细介绍请参考LwIP项目官网:https://savannah.nongnu.org/projects/lwip/ 45 46### LwIP在openharmony上的应用情况 47 48目前,openharmony源码树有两份LwIP: 49 501. third_party/lwip 51 * 源码形式编译 52 * 供liteos-a内核使用 53 * 还有一部分代码在kernel/liteos_a中,一起编译 542. vendor/hisi/hi3861/hi3861/third_party/lwip_sack 55 * hi3861-sdk的一部分 56 * 静态库形式编译 57 * 不可修改配置 58 * 可以查看当前配置(vend 59 60 61 62## 下载源码 63 64建议将本教程的源码下载到OpenHarmony源码树的顶层目录,即和`applications`、`build`等目录平级的地方: 65 66* 执行命令`git clone https://gitee.com/hihopeorg/HarmonyOS-IoT-Application-Development.git` 67 68 69 70## 文件说明 71 72文件: 73 74| 文件名 | 说明 | 75| ------------------ | --------------------------------------------------- | 76| BUILD.gn | 构建脚本,支持Hi3861、Hi3518、Hi3516开发板 | 77| demo_entry_cmsis.c | liteos-m程序入口,支持Hi3861 | 78| demo_entry_posix.c | liteos-a和Unix系统程序入口,Hi3516、Hi3518、PC | 79| Makefile | Unix系统构建脚本,支持Linux/Mac OS | 80| net_common.h | 系统网络接口头文件 | 81| net_demo.h | demo脚手架头文件 | 82| net_params.h | 网络参数,包括WiFi热点信息,服务器IP、端口信息 | 83| tcp_client_test.c | TCP客户端 | 84| tcp_server_test.c | TCP服务端 | 85| udp_client_test.c | UDP客户端 | 86| udp_server_test.c | UDP服务端 | 87| wifi_connecter.c | WiFi STA模式API的封装实现文件,比原始接口更容易使用 | 88| wifi_connecter.h | WiFi STA模式API的封装头文件,比原始接口更容易使用 | 89 90 91 92## Linux主机实验指南 93 94### 编译测试程序 95 96使用如下命令进行编译: 97 981. `make` 编译测试程序,该命令会生成4个可执行文件和几个.o文件 992. `make clean`删除可执行程序和.o文件 100 101### 运行测试程序 102 103Linux系统可以在同一台机器上,使用多个终端进行测试; 104 105* TCP客户端测试: 106 1. 在一个终端中使用netcat启动一个TCP服务端:`netcat -l 5678`; 107 2. 在另一个终端中启动TCP客户端测试程序:`./tcp_client_test 5678 127.0.0.1` ; 108 3. 在netcat终端中应该会出现TCP客户端测试程序发来的:`Hello`,输入`World`并回车,`World`将会发送到测试程序所在终端; 109* TCP服务端测试: 110 1. 在一个终端中启动TCP服务端测试程序:`./tcp_server_test 5678` ; 111 2. 在另一个终端中使用netcat启动一个TCP客户端,并尝试连接测试程序:`netcat 127.0.0.1 5678`; 112 3. 在netcat终端中输入`Hello`并回车,终端应该会再输出一行`Hello`,后面一行是TCP服务端测试程序发送回来的,同时终端上会有相关打印; 113* UDP客户端测试: 114 1. 在一个终端中使用netcat启动一个UDP服务端:`netcat -u -l 5678`; 115 2. 在另一个终端中启动UDP客户端测试程序:`./udp_client_test 5678 127.0.0.1` ; 116 3. 在netcat终端中应该会出现UDP客户端测试程序发来的`Hello.`,输入`World`并回车,`World`将会发送到测试程序所在终端; 117* UDP服务端测试: 118 1. 在一个终端中启动UDP服务端测试程序:`./udp_server_test 5678` ; 119 2. 在另一个终端中使用netcat启动一个UDP客户端,并尝试连接测试程序:`netcat -u 127.0.0.1 5678`; 120 3. 在netcat终端中输入`Hello.`并回车,终端应该会再输出一行`Hello.`,后面一行是UDP服务端测试程序是发送回来的,同时终端上会有相关打印; 121 122 123 124## Hi3861开发板实验指南 125 126### 准备网络环境 127 128在Hi3861开发板上运行上述四个测试程序之前,需要先准备网络环境: 129 1301. 准备一个无线路由器, 1312. 将Linux系统的PC连接到这个无线路由器, 132 * 如果是虚拟机运行的Linux系统,需要通过网线连接路由器,并且将虚拟机网口设置为“桥接网卡”,确保**能够从路由器分到IP地址**(这一点非常重要,因为默认是NAT模式,只能通过虚拟机访问外部环境,外部环境无法通过网络访问虚拟机); 133 134### 修改网络参数 135 136在Hi3861开发板上运行上述四个测试程序之前,需要根据你的无线路由、Linux系统IP修改`net_params.h`文件的相关代码: 137 138* PARAM_HOTSPOT_SSID 修改为你的热点名称 139* PARAM_HOTSPOT_PSK 修改为你的热点密码; 140* PARAM_SERVER_ADDR 修改为你的Linux主机IP地址; 141 142### 编译和烧录测试程序 143 144在Hi3861开发板上运行上述四个测试程序,需要分别编译、烧录程序; 145 1461. 需要修改`BUILD.gn`代码,取消你想要执行的测试程序的注释: 147 * 编译TCP客户端测试程序,取消 `sources = ["tcp_client_test.c"]` 的注释,保留其余三行的`sources`注释; 148 * 编译TCP服务端测试程序,取消 `sources = ["tcp_server_test.c"]` 的注释,保留其余三行的`sources`注释; 149 * 编译UDP客户端测试程序,取消 `sources = ["udp_client_test.c"]` 的注释,保留其余三行的`sources`注释; 150 * 编译UDP服务端测试程序,取消 `sources = ["udp_server_test.c"]` 的注释,保留其余三行的`sources`注释; 1512. 确认你已经修改了hi3861开发板的编译配置文件`build/lite/product/wifiiot.json`: 152 * `"//applications/sample/wifi-iot/app"`替换为:`"//HarmonyOS-IoT-Application-Development:app"` 1533. 使用`python build.py wifiiot`进行编译; 1544. 使用DevEco Device Tool或者HiBurn将二进制程序烧录到Hi3861开发板上; 1555. 烧录成功后暂时不要复位程序; 156 157 158 159### 运行测试程序 160 161Hi3861开发板上运行测试程序的操作流程和Linux上大体相同,只是Linux终端执行测试程序变成了——开发板复位后自动运行; 162 163* TCP客户端测试: 164 1. 在Linux终端中使用netcat启动一个TCP服务端:`netcat -l 5678`; 165 2. 连接开发板串口,复位开发板,板上程序启动后,首先会连接WiFi热点,然后会尝试连接到Linux上用netcat启动的TCP服务端; 166 3. 在Linux终端中应该会出现开发板上TCP客户端通过发来的`Hello`,输入`World`并回车,`World`将会发送到开发板上,同时开发板的串口会有相关打印; 167* TCP服务端测试: 168 1. 重新修改BUILD.gn,放开`sources = ["tcp_server_test.c"]`的注释,保留其他三行的注释,重新编译、烧录到开发板上; 169 2. 连接开发板串口,复位开发板,板上程序启动后,会首先连接WiFi热点,然后会启动TCP服务端,并监听`5678`端口; 170 * 这里需要从串口日志上查看开发板的IP地址,下一步操作需要用到 171 3. 在Linux终端中使用netcat启动一个TCP客户端,并尝试连接到开发板:`netcat board_ip 5678`,其中`board_ip`是开发板的IP地址; 172 4. 在Linux终端中输入`Hello`并回车,终端应该会再输出一行`Hello`,后面一行是开发板上TCP服务端序发送回来的,同时开发板的串口会有相关打印; 173* UDP客户端测试: 174 1. 重新修改BUILD.gn,放开`sources = ["udp_client_test.c"]`的注释,保留其他三行的注释,重新编译、烧录到开发板上; 175 2. 在Linux终端中使用netcat启动一个UDP服务端:`netcat -u -l 5678`; 176 3. 连接开发板串口,复位开发板,板上程序启动后,首先会连接WiFi热点,然后会尝试连接到Linux上用netcat启动的UDP服务端; 177 4. 在Linux终端中应该会出现UDP客户端测试程序发来的`Hello.`,输入`World`并回车,`World`将会发送到开发板上,同时开发板的串口会有相关打印; 178* UDP服务端测试: 179 1. 重新修改BUILD.gn,放开`sources = ["udp_server_test.c"]`的注释,保留其他三行的注释,重新编译、烧录到开发板上; 180 2. 连接开发板串口,复位开发板,板上程序启动后,会首先连接WiFi热点,然后会启动UDP服务端,并监听`5678`端口; 181 3. 在Linux终端中使用netcat启动一个UDP客户端,并尝试连接到开发板:`netcat -u 127.0.0.1 5678`; 182 4. 在Linux终端中输入`Hello.`并回车,终端应该会再输出一行`Hello.`,后面一行是UDP服务端测试程序是发送回来的,同时开发板的串口会有相关打印; 183 184 185 186### 【套件支持】 187 188##### 1. 套件介绍 http://www.hihope.org/pro/pro1.aspx?mtt=8 189 190##### 2. 套件购买 https://item.taobao.com/item.htm?id=622343426064&scene=taobao_shop 191 192##### 3. 技术资料 193 194- Gitee码云网站(OpenHarmony Sample Code等) **https://gitee.com/hihopeorg** 195 196- HiHope官网-资源中心(SDK包、技术文档下载)[**www.hihope.org**](http://www.hihope.org/) 197 198##### 4. 互动交流 199 200- 润和HiHope技术交流-微信群(加群管理员微信13605188699,发送文字#申请加入润和官方群#,予以邀请入群) 201- HiHope开发者社区-论坛 **https://bbs.elecfans.com/group_1429** 202- 润和HiHope售后服务群(QQ:980599547) 203- 售后服务电话(025-52668590)