1.简介
ThingsCloud 是新一代物联网设备统一接入平台,帮助企业在极短的时间内搭建个性化的物联网平台和应用,并适应不断变化的发展需求。目前广泛应用于制造、电力、能源、环境、农业、楼宇、家居、教育、交通、物流、自动化等领域。
ThingsCloud 可接入各类网关,传感器、执行器、控制器、通信模组、智能硬件等,实现数据采集、远程控制,数据分析、告警通知、智能联动。还可以零代码生成项目应用 SaaS 和用户应用 App,并开放 API 和实时消息,便于业务系统集成和扩展开发。
2.平台特点
快速接入:ThingsCloud提供开箱即用的云平台和云应用,使得硬件设备能够轻松接入云端,缩短项目交付周期,降低不确定性。
多功能支持:平台支持数据采集、实时控制、数据可视化、零代码应用开发、开放API等多种功能,满足不同场景的物联网需求。
灵活性强:ThingsCloud允许用户自定义设备和用户之间的交互方式,通过丰富的API接口和协议规范,实现设备的灵活接入和数据的灵活处理。
安全可靠:平台提供完善的安全机制和稳定可靠的云服务,确保数据的安全性和服务的可用性。
3.应用领域
智能家居:通过智能家居设备接入ThingsCloud,实现家居设备的远程控制和智能化管理。
农业物联网:利用农业传感器接入平台,实现农田环境的实时监测和智能灌溉等功能。
工业物联网:通过工业网关和PLC等设备接入平台,实现工业生产的智能化控制和数据分析。
智慧城市:借助城市中的各种物联网设备,如环境监测站、智能路灯等,实现城市的智能化管理和服务。
ThingsCloud平台提供从设备开发到落地运营的一站式解决方案,降低用户的使用门槛和成本。提供丰富的API接口和协议规范,方便用户进行二次开发和系统集成;拥有完善的技术支持和文档资源,帮助用户快速上手和解决问题;平台支持OEM服务,允许用户根据自己的需求进行品牌定制和界面设计。
4.设备接入案例
4.1注册账号
ThingsCloud平台地址:事物云
首次使用根据提示注册个人账号,登录控制台。
4.2 创建设备
(1)创建个人项目
(2)创建设备
4.3 平台接入
设备创建成功,可使用MQTT.fx测试接入平台。
配置成功即可看到设备上线。
4.4 平台订阅与发布
MQTT 全称是 Message Queuing Telemetry Transport,它是一种基于消息队列的轻量级应用层通信协议,实现了消息发布和订阅。设备可以作为客户端的形式通过它来发布和接收消息,实现数据上报和实时控制。
Publish 中填写发布到的主题为: attributes
内容格式为Json,示例如下:
{
"temperature": 34.2
}
从云端向设备下发数值,我们在设备端使用 MQTT 接入协议实时接收云平台下发的消息。
在设备端订阅如下主题:attributes/push
4.5 设置设备属性
添加设备属性信息,可以选择导入标准功能,也可以自定义功能。
4.6 STM32单片机接入平台
(1)本次使用ESP8266 WIFI模块接入平台,配置模式为STA+TCP客户端,采用MQTT协议接入,WIFI模式配置代码如下:
/****************STA+TCPclinet初始化*************
**
**
const char *STA_TCPCLINET[]=
{
"AT\r\n",//测试指令
"ATE0\r\n",//关回显
"AT+CWMODE=1\r\n",//设置STA模式
"AT+RST\r\n",//模块复位
"ATE0\r\n",//关回显
"AT+CWJAP=\"HUAWEIshui\",\"asdfghjkl12\"\r\n",//连接wifi
"AT+CIPMUX=0\r\n",//设置单连接
"AT+CIFSR\r\n",//查询IP
"AT+CIPSTART=\"TCP\",\"192.168.43.204\",8080\r\n",//连接服务器
"AT+CIPMODE=1\r\n",//设置透传模式
"AT+CIPSEND\r\n",//开始发送数据
};
*****************************************************/
u8 Esp8266_STA_TCPclinet_Init(u8 *wifi_name,u8 *wifi_key,u8 *server_ip,u16 server_port)
{
char buff[100];
/*退出透传模式*/
u8 i=0;
char *p=NULL;
for(i=0;i<5;i++)
{
Usartx_SendString(USART3,(u8 *)"+++");//退出透传模式
Delay_Ms(500);
if(Esp8266_SendCmdCheckStat("AT\r\n","OK\r\n")==0)
{
i=0;
break;
}
}
if(i!=0)
{
printf("退出透传模式失败\r\n");
return 0xff;
}
printf("1.发送测试指令\r\n");
if(Esp8266_SendCmdCheckStat("AT\r\n","OK\r\n"))return 1;
printf("2.关回显\r\n");
if(Esp8266_SendCmdCheckStat("ATE0\r\n","OK\r\n"))return 2;
printf("3.设置模式\r\n");
if(Esp8266_SendCmdCheckStat("AT+CWMODE=1\r\n","OK\r\n"))return 3;
printf("4.模块复位\r\n");
if(Esp8266_SendCmdCheckStat("AT+RST\r\n","OK\r\n"))return 4;
Delay_Ms(1000);
Delay_Ms(1000);
printf("5.关回显\r\n");
if(Esp8266_SendCmdCheckStat("ATE0\r\n","OK\r\n"))return 5;
printf("6.连接WIFI\r\n");
if(ESP8266_ConectWifi(wifi_name,wifi_key))return 6;
printf("7.设置单连接\r\n");
if(Esp8266_SendCmdCheckStat("AT+CIPMUX=0\r\n","OK"))return 7;
printf("8.查询IP地址\r\n");
if(Esp8266_SendCmdCheckStat("AT+CIFSR\r\n","OK\r\n"))return 8;
printf("ip:%s\r\n",usart3_rx_buff);//打印IP信息
/*
ip:+CIFSR:STAIP,"192.168.43.111"
+CIFSR:STAMAC,"84:f3:eb:a6:be:f9"
OK
*/
i=0;
p=strstr((char *)usart3_rx_buff,"STAIP,\"");//查找字符串
if(p!=NULL)
{
p+=7;
while((*p!='"') && (*p!='\0'))
{
buff[i++]=*p++;
}
}
buff[i]='\0';
printf("ip:%s\r\n",buff);
snprintf(buff,sizeof(buff),"AT+CIPSTART=\"TCP\",\"%s\",%d\r\n",server_ip,server_port);
// printf("buff:%s\r\n",buff);
printf("9.连接服务器\r\n");
if(Esp8266_SendCmdCheckStat(buff,"OK"))return 9;
printf("配置透传模式\r\n");
if(Esp8266_SendCmdCheckStat("AT+CIPMODE=1\r\n","OK\r\n"))return 10;
printf("开始发送数据\r\n");
if(Esp8266_SendCmdCheckStat("AT+CIPSEND\r\n",">"))return 11;
return 0;
}
(2)配置平台连接信息,接入ThingsCloud平台。
#define WIFI_NAME "huawei_ashui"//WIFI名
#define WIFI_PASSWORD "asdfghjkl"//wifi密码
#define SERVER_IP "sh-3-mqtt.iot-api.com"//服务器IP
#define SERVER_PORT 1883 //端口号
//客户端ID:随便填写
#define ClientID "stm32"
//用户名和密码可使用密码生成工具完成
#define Username "buq0p0x3ffgwttlzar"
#define Password "qyJfLfggMuT"//密文
#define SET_TOPIC "attributes/push"//订阅
#define POST_TOPIC "attributes"//发布
(3)初始化WIFI,连接云平台
while(1)
{
stat=Esp8266_STA_TCPclinet_Init((u8 *)WIFI_NAME,(u8 *)WIFI_PASSWORD,(u8 *)SERVER_IP,SERVER_PORT);
if(stat==0)break;
Delay_Ms(500);
printf("stat=%d\r\n",stat);
}
printf("服务器连接成功\r\n");
while(1)
{
MQTT_Init();
stat=MQTT_Connect(ClientID,Username,Password);
if(stat==0)break;
Delay_Ms(500);
printf("正在连接....\r\n");
}
printf("连接成功\r\n");
stat=MQTT_SubscribeTopic(SET_TOPIC,0,1);
if(stat)printf("订阅失败\r\n");
else printf("订阅成功\r\n");
(4)发布数据与订阅平台数据。
while(1)
{
if(usart3_flag)
{
idex=0;
for(i=0;i<usart3_cnt;i++)
{
//printf("%c",usart3_rx_buff[i]);
if(usart3_rx_buff[i]!='\0') buffer[idex++]=usart3_rx_buff[i];
}
buffer[idex]='\0';
/*
attributes/push{"red_state":true}
attributes/push{"red_state":true}
attributes/push{"sound_state":true}
*/
if(Weather_analysis((u8*)buffer,(u8 *)"red_state",data)==0)
{
if(strstr((char *)data,"true"))
{
LED1=LED2=LED3=LED4=0;
}
else if(strstr((char *)data,"false"))
{
LED1=LED2=LED3=LED4=1;
}
}
else if(Weather_analysis((u8*)buffer,(u8 *)"sound_state",data)==0)
{
if(strstr((char *)data,"true"))
{
BEEP=1;
}
else if(strstr((char *)data,"false"))
{
BEEP=0;
}
}
usart3_cnt=0;
usart3_flag=0;
}
Delay_Ms(1);
time++;
time2++;
cnt++;
if(time2>=500)
{
time2=0;
temp=DS18B20_GetTemp()*0.0625;
snprintf(buffer,sizeof(buffer),"Temp:%.1f",temp);
OLED_show_Str(3,24,16,buffer);
light=ADC_GetRegluarChannl(8);
snprintf(buffer,sizeof(buffer),"L:%04d lux",light);
OLED_show_Str(3,24+16,16,buffer);
OLED_Refresh();//更新显示
}
if(time>=40000)
{
time=0;
MQTT_SentHeart();//发送心跳包
}
if(cnt>=10000)
{
cnt=0;
sprintf(mqtt_message,"{\"temperature\":%.1f,\"Light\":%d}",temp,light);//温度
MQTT_PublishData(POST_TOPIC,mqtt_message,0);
}
}
4.7 STM32接入效果
开发板界面效果:
平台数据效果:
5.设置微信小程序界面
Thingscloud平台实现了设备和云平台的通信,并通过规则引擎和定时任务快速完成了一些云端功能,现在,我们希望给设备的最终用户提供一款 App,用于查看设备数据和控制设备功能。
ThingsCloud 不仅是开放的物联网设备接入平台,同时也是零代码应用开发平台,不论您是集团公司还是初创团队,或者是个人开发者,都可以在极短的时间内快速生成物联网应用,包括 SaaS 应用和手机 App。
5.1 创建用户
要使用Thingscloud平台微信小程序,首先需要创建用户,关联设备。
单击应用名字,即可扫码登录对应平台。
5.2 设计小程序界面
(1)关联用户
2.应用界面设计
3.应用界面