博客
关于我
wemos D1 arduino物联网开发板应用笔记7-STA模式下TCP Client通信
阅读量:601 次
发布时间:2019-03-12

本文共 2051 字,大约阅读时间需要 6 分钟。

前言

本文研究WeMos D1如何在STA模式下进行TCP Client通信,模块直接连接AP(手机热点或者路由器),进入局域网中和其他无线设备通信,局域网中其他设备作为服务端,WIFI模块作为客户端。

一、基础知识

1.模块连接AP

路由器名字:lxy2305,密码:123456789a:

WiFi.mode(WIFI_STA);WiFi.begin(ssid, passwd);

2.Socket套接字实现TCP Client流程

Socket解套接字使用流程如下:

在这里插入图片描述

3.WiFiClient库简介

在Wemos D1实际开发中,并不需要直接操作socket套接字进行TCP通信,使用WiFiClient库便可进行快速开发,其百度脑图如下:

在这里插入图片描述

从上图中可以看出WiFiClient库主要包含连接、通信、获取状态三类API,函数具体用法如下表:

在这里插入图片描述

二、实例

1. 程序

本程序实现Wemos D1作为TCP Client连接局域网中TCP Server,然后进行数据通信。

#include 
char* ssid = "lxy2305";char* passwd = "123456789a";const uint16_t port = 8089;const char * host = "192.168.1.7"; // ipWiFiClient client; void setup() { Serial.begin(115200); WiFi.mode(WIFI_STA); WiFi.begin(ssid, passwd); Serial.println("connecting to router... "); //等待wifi连接成功 while (WiFi.status() != WL_CONNECTED) { Serial.print("."); delay(500); } Serial.println(""); Serial.print("WiFi connected, local IP address:"); Serial.println(WiFi.localIP()); delay(500); Serial.print("connecting to "); Serial.println(host); if (!client.connect(host, port)) { Serial.println("connection failed"); Serial.println("wait 5 sec..."); delay(5000); return; }else { Serial.println("connect to tcp server success."); Serial.println("Send this data to tcp server"); client.println(String("hello tcp server")); }} void loop() { //读取从tcp server返回到响应数据 String recv_data = client.readStringUntil('\r'); Serial.println(recv_data); if (0 == recv_data.compareTo("exit")) { Serial.println("closing connection"); client.stop(); } delay(200);}

上述程序中,首先设置模块为WIFI_STA模式,接着连接路由器和网络中TCP服务器(192.168.1.7, 8089),然后发送"hello tcp server"给服务器,接着在loop()函数中接收TCP服务器发过来的数据,如果不是"exit",串口打印出来,否则关闭TCP连接。

三、运行

1 获取电脑IP地址

​电脑连接路由器,并在CMD控制台输入ipconfig获取当前笔记本IP地址

在这里插入图片描述

2 使用网络助手创建TCP Server

打开NetAssist.exe网络调试助手,也可使用其他网路助手,也可使用其他网路助手,网络端口设置为8089。

在这里插入图片描述

3.下载运行

程序编译上传后设备执行Log如下:

在这里插入图片描述

从上图可知,TCP Client功能正常运行,可以完成连接TCP Server、发送数、接收数据、关闭等功能。

四、结语

本节完,实际操作过程中需要注意的地方有如下几点:

(1)使用网络助手

首先确定电脑当前IP地址,端口可以自己定。

(2)获取源码

如您在使用过程中有任何问题,请加QQ群进一步交流。

QQ交流群:906015840 (备注:物联网项目交流)

公众号:物联网客栈,扫码关注,回复wemos即可。

在这里插入图片描述
一叶孤沙出品:一沙一世界,一叶一菩提

转载地址:http://aahtz.baihongyu.com/

你可能感兴趣的文章
Nginx:NginxConfig可视化配置工具安装
查看>>
ngModelController
查看>>
ngrok | 内网穿透,支持 HTTPS、国内访问、静态域名
查看>>
ngrok内网穿透可以实现资源共享吗?快解析更加简洁
查看>>
NHibernate学习[1]
查看>>
NHibernate异常:No persister for的解决办法
查看>>
NIFI1.21.0_java.net.SocketException:_Too many open files 打开的文件太多_实际操作---大数据之Nifi工作笔记0051
查看>>
NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
查看>>
NIFI1.21.0_Mysql到Mysql增量CDC同步中_补充_更新时如果目标表中不存在记录就改为插入数据_Postgresql_Hbase也适用---大数据之Nifi工作笔记0059
查看>>
NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
查看>>
NIFI1.21.0最新版本安装_连接phoenix_单机版_Https登录_什么都没改换了最新版本的NIFI可以连接了_气人_实现插入数据到Hbase_实际操作---大数据之Nifi工作笔记0050
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_插入修改删除增量数据实时同步_通过分页解决变更记录过大问题_01----大数据之Nifi工作笔记0053
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表或全表增量同步_实现指定整库同步_或指定数据表同步配置_04---大数据之Nifi工作笔记0056
查看>>
NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_生成插入Sql语句_实际操作02---大数据之Nifi工作笔记0041
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
查看>>