10-51单片机ESP8266学习-AT指令(ESP8266连接路由器,建立TCP服务器,分别和C#TCP客户端和AndroidTCP客户端通信+花生壳远程通信)...

本文主要是介绍10-51单片机ESP8266学习-AT指令(ESP8266连接路由器,建立TCP服务器,分别和C#TCP客户端和AndroidTCP客户端通信+花生壳远程通信)...,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

http://www.cnblogs.com/yangfengwu/p/8871464.html  

 

先把源码和资料链接放到这里

源码链接:https://pan.baidu.com/s/1wT8KAOIzvkOXXNpkDI7E8g 
提取码:1q9y 

 

前几篇是介绍的模块建立TCP服务器,不连接路由器,然后进行通信呢,连接路由器最大的好处就是可以实现远程控制

今天呢有喜有悲,悲喜交加,板子终于开始贴片了....

 

今天最让人开心的事情是自己刚做的GPRS的板子和51学习的板子虽然自己马虎画错了一个地方起初也不知道...,但是嘉立创的客服今天打电话说自己那个地方有点问题,然后给自己修改了过来,,,现在感觉在嘉立创做板子就是放心,真的.不是打广告哈,感觉人家的服务就是好

现在看一下自己画的不对的地方

现在只看机械层和底层

直接一个打孔就干掉了这条线..................机械层在画板子的时候如果不注意........下次一定要时刻提醒着自己,画完板子单独看一下机械层和顶层或底层,容易忘

 

现在接着说

其实连接路由器就一条指令

其实应该还有配置设置自己的IP地址固定住,一会在说,咱先连接路由器,然后开启TCP,然后看一下模块的IP,然后进行通信

刚才测试发现一个问题,如果配置了连接无线了(而且保存了),那么上电后模块

 

那么咱们以前的程序就不能用了,,,不能是等待3s后判断有没有ready,,,,应该是复位以后一直检测有没有回复ready,超过3S没有回复就再发送一次指令,发送的指令超过3次

那么咱就重新开始

看一个就行,,,下面的都一样

    /*下面的都是一样的模子,注释就写一个*/Cnt = 0;CntCnt = 0;SendDataFlage = 1;while(1){if(SendDataFlage == 1)//发送指令
        {SendDataFlage = 0;printf("8266RST\r\n");//这个不是什么指令,我先用串口调试助手模拟P0_0 = 1;//这个灯作为指示灯,发送个指令就亮,ESP_Rst();//复位8266
       }DelayMs(1);if(UsartFlage == 1)//串口接收到数据
        {UsartFlage = 0;if(strstr(UsartReceive, "ready"))//有没有ready
            {P0_0 = 0;//接收到正确的回复就灭DelayMs(500);break;}}Cnt ++;if(Cnt>=3000)//每间隔3S发送一次数据
        {SendDataFlage = 1;//允许发送数据Cnt = 0;CntCnt++;}if(CntCnt>=3)//超过三次重新开始
        {CntCnt = 0;Cnt = 0;goto start;}}

 

 

所以现在的程序

#define MAIN_C_
#include "include.h"/**
* 介绍:  主函数
* 说明:  每间隔1S发送一次温湿度数据
* 说明:  返回串口接收到的数据,发送方式为中断发送
* 说明:  None
* 说明:  None
* 支持:  QQ946029359 --群 607064330
* 淘宝:  https://shop411638453.taobao.com/
* 作者:  小五
**/int Cnt = 0;
unsigned char CntCnt = 0;
unsigned char SendDataFlage = 0;unsigned char ConnectID = 0;
unsigned char i=0;
unsigned char SendDataValue[6]={0xaa,0x55};
int ReadDHT11delay = 0;//设置多少时间读一次DHT11;
void main()
{InitUART(115200);InitTimer0();start:/*下面的都是一样的模子,注释就写一个*/Cnt = 0;CntCnt = 0;SendDataFlage = 1;while(1){if(SendDataFlage == 1)//发送指令
        {SendDataFlage = 0;printf("8266RST\r\n");//这个不是什么指令,我先用串口调试助手模拟P0_0 = 1;//这个灯作为指示灯,发送个指令就亮,ESP_Rst();//复位8266
    }DelayMs(1);if(UsartFlage == 1)//串口接收到数据
        {UsartFlage = 0;if(strstr(UsartReceive, "ready"))//有没有ready
            {P0_0 = 0;//接收到正确的回复就灭DelayMs(500);break;}}Cnt ++;if(Cnt>=3000)//每间隔3S发送一次数据
        {SendDataFlage = 1;//允许发送数据Cnt = 0;CntCnt++;}if(CntCnt>=3)//超过三次重新开始
        {CntCnt = 0;Cnt = 0;goto start;}}/*配置连接路由器*/Cnt = 0;CntCnt = 0;SendDataFlage = 1;while(1){if(SendDataFlage){SendDataFlage = 0;printf("AT+CWJAP_DEF=\"qqqqq\",\"11223344\"\r\n");//连接路由器P0_0 = 1;}DelayMs(1);if(UsartFlage == 1){UsartFlage = 0;if(strstr(UsartReceive, "OK")){P0_0 = 0;DelayMs(500);break;}}Cnt ++;if(Cnt>=3000)//每间隔3S发送一次数据
        {SendDataFlage = 1;//允许发送数据Cnt = 0;CntCnt++;}if(CntCnt>=3)//超过三次重新开始
        {CntCnt = 0;Cnt = 0;goto start;}}/*配置模式*/Cnt = 0;CntCnt = 0;SendDataFlage = 1;while(1){if(SendDataFlage){SendDataFlage = 0;printf("AT+CWMODE_DEF=3\r\n");//AP+StationP0_0 = 1;}DelayMs(1);if(UsartFlage == 1){UsartFlage = 0;if(strstr(UsartReceive, "OK")){P0_0 = 0;DelayMs(500);break;}}Cnt ++;if(Cnt>=3000)//每间隔3S发送一次数据
        {SendDataFlage = 1;//允许发送数据Cnt = 0;CntCnt++;}if(CntCnt>=3)//超过三次重新开始
        {CntCnt = 0;Cnt = 0;goto start;}}/*多连接*/Cnt = 0;CntCnt = 0;SendDataFlage = 1;while(1){if(SendDataFlage){SendDataFlage = 0;printf("AT+CIPMUX=1\r\n");//启动多连接P0_0 = 1;}DelayMs(1);if(UsartFlage == 1){UsartFlage = 0;if(strstr(UsartReceive, "OK")){P0_0 = 0;DelayMs(500);break;}}Cnt ++;if(Cnt>=3000)//每间隔3S发送一次数据
        {SendDataFlage = 1;//允许发送数据Cnt = 0;CntCnt++;}if(CntCnt>=3)//超过三次重新开始
        {CntCnt = 0;Cnt = 0;goto start;}}/*创建服务器*/Cnt = 0;CntCnt = 0;SendDataFlage = 1;while(1){if(SendDataFlage){SendDataFlage = 0;printf("AT+CIPSERVER=1,1001\r\n");//创建服务器P0_0 = 1;}DelayMs(1);if(UsartFlage == 1){UsartFlage = 0;if(strstr(UsartReceive, "OK")){P0_0 = 0;DelayMs(500);break;}}Cnt ++;if(Cnt>=3000)//每间隔3S发送一次数据
        {SendDataFlage = 1;//允许发送数据Cnt = 0;CntCnt++;}if(CntCnt>=3)//超过三次重新开始
        {CntCnt = 0;Cnt = 0;goto start;}}/*让小灯闪一闪,算是说明正确执行了把*/P0_0 = 0;DelayMs(200);P0_0 = 1;DelayMs(200);P0_0 = 0;DelayMs(200);P0_0 = 1;DelayMs(200);P0_0 = 0;while(1){if(TimeCnt>=200){TimeCnt = 0;DHT11_Receive(); }if(UsartFlage == 1)//返回接收的数据
        {UsartFlage = 0;for(i=0;i<10;i++)//找到开始的数据位置,有的固件数据前头有换行,有的没有
            {if(UsartReceive[i]=='+' && UsartReceive[i+1]=='I'&& UsartReceive[i+2]=='P')//判断数据的头
                {ConnectID = UsartReceive[i+5];//得到是几号连接的if(ConnectID>=0x30 && ConnectID<=0x34)//得到的ID号有没有越界
                    {for(i=6;i<15;i++)//找到 : 在哪里,才知道真实数据在哪里
                         {if(UsartReceive[i] == ':'){if(UsartReceive[i+1]==0xaa  && UsartReceive[i+2]==0x55){switch(UsartReceive[i+3]){case 0x01:  SendDataValue[2] = 0x01;SendDataValue[3] = DHT11Data[0];SendDataValue[4] = DHT11Data[2];ESPSendData(ConnectID-0x30,5,SendDataValue,1000);break;//发送温湿度数据case 0x02: if(UsartReceive[i+4] == 0x00){P0_0 = 0;} else if(UsartReceive[i+4] == 0xff){P0_0 = 1;}break;default:break;                          }break;//结束for(i=6;i<15)
                                    }}}break;//结束for(i=0;i<10;i++)
                    }}}}}
}

多加了一个指令(在复位后执行)

 

 对了\"  在前面介绍了哈  就是代表"

程序下进去了,现在看一下自己的路由器列表

现在测试通信

 

 

用咱做的TCP客户端测试

 

 

 

既然连接路由器了,就可以实现远程了

先用花生壳,,不知道还能不能用,花了6块钱都买了一年了.....

详细的购买花生壳过程,请参考我的这篇文章

http://www.cnblogs.com/yangfengwu/p/7736296.html#3941866

先映射

 

 

 

 

 

 对了说一下,其实直接连接模块的无线也是可以通信的....

现在测试C#TCP客户端

现在用花生壳连接

 

 

 

看来是解析域名出了问题直接百度

咱试一试

可以啦.....

接着再修改一下单片机的程序,8266连接路由器之后是不是因为自动分配的IP,所以对于咱来说是不是不方便哈,如果IP地址变了,,,还要查看,然后花生壳还要跟着修改,,,

现在咱固定模块的IP

两种方式一种是用模块的指令,另一种是在路由器里面修改

咱先用指令修改

 

我先用串口助手配置一下看看回的内容

 

 

 

现在做单片机程序..其实就是加一个指令

/*配置连接路由器后分得的IP地址是多少*/Cnt = 0;CntCnt = 0;SendDataFlage = 1;while(1){if(SendDataFlage){SendDataFlage = 0;printf("AT+CIPSTA_DEF=\"192.168.1.106\",\"192.168.1.1\",\"255.255.255.0\"\r\n");P0_0 = 1;}DelayMs(1);if(UsartFlage == 1){UsartFlage = 0;if(strstr(UsartReceive, "OK")){P0_0 = 0;DelayMs(500);break;}}Cnt ++;if(Cnt>=3000)//每间隔3S发送一次数据
        {SendDataFlage = 1;//允许发送数据Cnt = 0;CntCnt++;}if(CntCnt>=3)//超过三次重新开始
        {CntCnt = 0;Cnt = 0;goto start;}}

 

现在也设置一下花生壳

咱用手机远程连接一下

 

现在用路由器修改

咱先把程序修改的屏蔽掉,

    /*配置连接路由器后分得的IP地址是多少*/
//     Cnt = 0;
//     CntCnt = 0;
//     SendDataFlage = 1;
//     while(1)
//     {
//         if(SendDataFlage)
//         {
//             SendDataFlage = 0;
//             printf("AT+CIPSTA_DEF=\"192.168.1.106\",\"192.168.1.1\",\"255.255.255.0\"\r\n");
//           P0_0 = 1;
//         }
//         
//         DelayMs(1);
//         if(UsartFlage == 1)
//         {
//       UsartFlage = 0;
//             if(strstr(UsartReceive, "OK"))
//             {
//                 P0_0 = 0;
//                 DelayMs(500);
//                 break;
//             }
//     }
//         
//         Cnt ++;
//         if(Cnt>=3000)//每间隔3S发送一次数据
//         {
//             SendDataFlage = 1;//允许发送数据
//             Cnt = 0;
//             CntCnt++;
//     }
//         if(CntCnt>=3)//超过三次重新开始
//         {
//             CntCnt = 0;
//             Cnt = 0;
//             goto start;
//         }
//   }

 

噢噢噢噢噢噢噢知道原因了

 

可以先恢复出厂设置

 

 

 

 不过模块有问题了.................

 

 哦哦哦哦哦知道原因了....要先设置模式默认AP模式是不可以连接路由器的................以前的程序全部有BUG...................

#define MAIN_C_
#include "include.h"/**
* 介绍:  主函数
* 说明:  每间隔1S发送一次温湿度数据
* 说明:  返回串口接收到的数据,发送方式为中断发送
* 说明:  None
* 说明:  None
* 支持:  QQ946029359 --群 607064330
* 淘宝:  https://shop411638453.taobao.com/
* 作者:  小五
**/int Cnt = 0;
unsigned char CntCnt = 0;
unsigned char SendDataFlage = 0;unsigned char ConnectID = 0;
unsigned char i=0;
unsigned char SendDataValue[6]={0xaa,0x55};
int ReadDHT11delay = 0;//设置多少时间读一次DHT11;
void main()
{InitUART(115200);InitTimer0();start:/*下面的都是一样的模子,注释就写一个*/Cnt = 0;CntCnt = 0;SendDataFlage = 1;while(1){if(SendDataFlage == 1)//发送指令
        {SendDataFlage = 0;printf("8266RST\r\n");//这个不是什么指令,我先用串口调试助手模拟P0_0 = 1;//这个灯作为指示灯,发送个指令就亮,ESP_Rst();//复位8266
    }DelayMs(1);if(UsartFlage == 1)//串口接收到数据
        {UsartFlage = 0;if(strstr(UsartReceive, "ready"))//有没有ready
            {P0_0 = 0;//接收到正确的回复就灭DelayMs(500);break;}}Cnt ++;if(Cnt>=3000)//每间隔3S发送一次数据
        {SendDataFlage = 1;//允许发送数据Cnt = 0;CntCnt++;}if(CntCnt>=3)//超过三次重新开始
        {CntCnt = 0;Cnt = 0;goto start;}}/*配置模式*/Cnt = 0;CntCnt = 0;SendDataFlage = 1;while(1){if(SendDataFlage){SendDataFlage = 0;printf("AT+CWMODE_DEF=3\r\n");//AP+StationP0_0 = 1;}DelayMs(1);if(UsartFlage == 1){UsartFlage = 0;if(strstr(UsartReceive, "OK")){P0_0 = 0;DelayMs(500);break;}}Cnt ++;if(Cnt>=3000)//每间隔3S发送一次数据
        {SendDataFlage = 1;//允许发送数据Cnt = 0;CntCnt++;}if(CntCnt>=3)//超过三次重新开始
        {CntCnt = 0;Cnt = 0;goto start;}}//     /*配置连接路由器后分得的IP地址是多少*/
//     Cnt = 0;
//     CntCnt = 0;
//     SendDataFlage = 1;
//     while(1)
//     {
//         if(SendDataFlage)
//         {
//             SendDataFlage = 0;
//             printf("AT+CIPSTA_DEF=\"192.168.1.106\",\"192.168.1.1\",\"255.255.255.0\"\r\n");
//           P0_0 = 1;
//         }
//         
//         DelayMs(1);
//         if(UsartFlage == 1)
//         {
//       UsartFlage = 0;
//             if(strstr(UsartReceive, "OK"))
//             {
//                 P0_0 = 0;
//                 DelayMs(500);
//                 break;
//             }
//     }
//         
//         Cnt ++;
//         if(Cnt>=3000)//每间隔3S发送一次数据
//         {
//             SendDataFlage = 1;//允许发送数据
//             Cnt = 0;
//             CntCnt++;
//     }
//         if(CntCnt>=3)//超过三次重新开始
//         {
//             CntCnt = 0;
//             Cnt = 0;
//             goto start;
//         }
//   }/*配置连接路由器*/Cnt = 0;CntCnt = 0;SendDataFlage = 1;while(1){if(SendDataFlage){SendDataFlage = 0;printf("AT+CWJAP_DEF=\"qqqqq\",\"11223344\"\r\n");//连接路由器P0_0 = 1;}DelayMs(1);if(UsartFlage == 1){UsartFlage = 0;if(strstr(UsartReceive, "OK")){P0_0 = 0;DelayMs(500);break;}}Cnt ++;if(Cnt>=3000)//每间隔3S发送一次数据
        {SendDataFlage = 1;//允许发送数据Cnt = 0;CntCnt++;}if(CntCnt>=3)//超过三次重新开始
        {CntCnt = 0;Cnt = 0;goto start;}}/*多连接*/Cnt = 0;CntCnt = 0;SendDataFlage = 1;while(1){if(SendDataFlage){SendDataFlage = 0;printf("AT+CIPMUX=1\r\n");//启动多连接P0_0 = 1;}DelayMs(1);if(UsartFlage == 1){UsartFlage = 0;if(strstr(UsartReceive, "OK")){P0_0 = 0;DelayMs(500);break;}}Cnt ++;if(Cnt>=3000)//每间隔3S发送一次数据
        {SendDataFlage = 1;//允许发送数据Cnt = 0;CntCnt++;}if(CntCnt>=3)//超过三次重新开始
        {CntCnt = 0;Cnt = 0;goto start;}}/*创建服务器*/Cnt = 0;CntCnt = 0;SendDataFlage = 1;while(1){if(SendDataFlage){SendDataFlage = 0;printf("AT+CIPSERVER=1,1001\r\n");//创建服务器P0_0 = 1;}DelayMs(1);if(UsartFlage == 1){UsartFlage = 0;if(strstr(UsartReceive, "OK")){P0_0 = 0;DelayMs(500);break;}}Cnt ++;if(Cnt>=3000)//每间隔3S发送一次数据
        {SendDataFlage = 1;//允许发送数据Cnt = 0;CntCnt++;}if(CntCnt>=3)//超过三次重新开始
        {CntCnt = 0;Cnt = 0;goto start;}}/*让小灯闪一闪,算是说明正确执行了把*/P0_0 = 0;DelayMs(200);P0_0 = 1;DelayMs(200);P0_0 = 0;DelayMs(200);P0_0 = 1;DelayMs(200);P0_0 = 0;while(1){if(TimeCnt>=200){TimeCnt = 0;DHT11_Receive(); }if(UsartFlage == 1)//返回接收的数据
        {UsartFlage = 0;for(i=0;i<10;i++)//找到开始的数据位置,有的固件数据前头有换行,有的没有
            {if(UsartReceive[i]=='+' && UsartReceive[i+1]=='I'&& UsartReceive[i+2]=='P')//判断数据的头
                {ConnectID = UsartReceive[i+5];//得到是几号连接的if(ConnectID>=0x30 && ConnectID<=0x34)//得到的ID号有没有越界
                    {for(i=6;i<15;i++)//找到 : 在哪里,才知道真实数据在哪里
                         {if(UsartReceive[i] == ':'){if(UsartReceive[i+1]==0xaa  && UsartReceive[i+2]==0x55){switch(UsartReceive[i+3]){case 0x01:  SendDataValue[2] = 0x01;SendDataValue[3] = DHT11Data[0];SendDataValue[4] = DHT11Data[2];ESPSendData(ConnectID-0x30,5,SendDataValue,1000);break;//发送温湿度数据case 0x02: if(UsartReceive[i+4] == 0x00){P0_0 = 0;} else if(UsartReceive[i+4] == 0xff){P0_0 = 1;}break;default:break;                          }break;//结束for(i=6;i<15)
                                    }}}break;//结束for(i=0;i<10;i++)
                    }}}}}
}

 

 

 

 

花生壳刚才检测原因关了,现在重新用花生壳映射

 

 电脑端就不测试了,,,

其实这篇就改了一下单片机和C#的程序

 

 

今天...以前的源码全有BUG.............唉

补充:

如果路由器不能上网,可以这样

 

 注意点:

路由器桥接手机的WIFI信号后,如果没有注意到路由器分得的IP就登录不进路由器了,因为我们登录不进路由器,所以映射的时候怎么知道WIFI的IP地址,咱们可以设置WiFi固定住IP,但是网关和子网掩码呢可以看电脑的

 

 

 

 然后花生壳映射

 

 另一个手机或者本机连接这个就可以

 

下一篇链接

https://www.cnblogs.com/yangfengwu/p/8970580.html

https://yq.aliyun.com/articles/585610

 

转载于:https://www.cnblogs.com/yangfengwu/p/8887909.html

这篇关于10-51单片机ESP8266学习-AT指令(ESP8266连接路由器,建立TCP服务器,分别和C#TCP客户端和AndroidTCP客户端通信+花生壳远程通信)...的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:https://blog.csdn.net/weixin_30247781/article/details/97808488
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/313301

相关文章

电脑蓝牙连不上怎么办? 5 招教你轻松修复Mac蓝牙连接问题的技巧

《电脑蓝牙连不上怎么办?5招教你轻松修复Mac蓝牙连接问题的技巧》蓝牙连接问题是一些Mac用户经常遇到的常见问题之一,在本文章中,我们将提供一些有用的提示和技巧,帮助您解决可能出现的蓝牙连接问... 蓝牙作为一种流行的无线技术,已经成为我们连接各种设备的重要工具。在 MAC 上,你可以根据自己的需求,轻松地

Windows Server 2025 搭建NPS-Radius服务器的步骤

《WindowsServer2025搭建NPS-Radius服务器的步骤》本文主要介绍了通过微软的NPS角色实现一个Radius服务器,身份验证和证书使用微软ADCS、ADDS,具有一定的参考价... 目录简介示意图什么是 802.1X?核心作用802.1X的组成角色工作流程简述802.1X常见应用802.

宝塔安装的MySQL无法连接的情况及解决方案

《宝塔安装的MySQL无法连接的情况及解决方案》宝塔面板是一款流行的服务器管理工具,其中集成的MySQL数据库有时会出现连接问题,本文详细介绍两种最常见的MySQL连接错误:“1130-Hostisn... 目录一、错误 1130:Host ‘xxx.xxx.xxx.xxx’ is not allowed

Python模拟串口通信的示例详解

《Python模拟串口通信的示例详解》pySerial是Python中用于操作串口的第三方模块,它支持Windows、Linux、OSX、BSD等多个平台,下面我们就来看看Python如何使用pySe... 目录1.win 下载虚www.chinasem.cn拟串口2、确定串口号3、配置串口4、串口通信示例5

C#使用MQTTnet实现服务端与客户端的通讯的示例

《C#使用MQTTnet实现服务端与客户端的通讯的示例》本文主要介绍了C#使用MQTTnet实现服务端与客户端的通讯的示例,包括协议特性、连接管理、QoS机制和安全策略,具有一定的参考价值,感兴趣的可... 目录一、MQTT 协议简介二、MQTT 协议核心特性三、MQTTNET 库的核心功能四、服务端(BR

C#继承之里氏替换原则分析

《C#继承之里氏替换原则分析》:本文主要介绍C#继承之里氏替换原则,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C#里氏替换原则一.概念二.语法表现三.类型检查与转换总结C#里氏替换原则一.概念里氏替换原则是面向对象设计的基本原则之一:核心思想:所有引py

使用Nginx配置文件服务器方式

《使用Nginx配置文件服务器方式》:本文主要介绍使用Nginx配置文件服务器方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 为什么选择 Nginx 作为文件服务器?2. 环境准备3. 配置 Nginx 文件服务器4. 将文件放入服务器目录5. 启动 N

C#实现访问远程硬盘的图文教程

《C#实现访问远程硬盘的图文教程》在现实场景中,我们经常用到远程桌面功能,而在某些场景下,我们需要使用类似的远程硬盘功能,这样能非常方便地操作对方电脑磁盘的目录、以及传送文件,这次我们将给出一个完整的... 目录引言一. 远程硬盘功能展示二. 远程硬盘代码实现1. 底层业务通信实现2. UI 实现三. De

C#通过进程调用外部应用的实现示例

《C#通过进程调用外部应用的实现示例》本文主要介绍了C#通过进程调用外部应用的实现示例,以WINFORM应用程序为例,在C#应用程序中调用PYTHON程序,具有一定的参考价值,感兴趣的可以了解一下... 目录窗口程序类进程信息类 系统设置类 以WINFORM应用程序为例,在C#应用程序中调用python程序

基于C#实现MQTT通信实战

《基于C#实现MQTT通信实战》MQTT消息队列遥测传输,在物联网领域应用的很广泛,它是基于Publish/Subscribe模式,具有简单易用,支持QoS,传输效率高的特点,下面我们就来看看C#实现... 目录1、连接主机2、订阅消息3、发布消息MQTT(Message Queueing Telemetr