STM32+ESP8266连接阿里云物联网平台

一、硬件准备

我本次使用的是stm32f103c8t6,esp8266,DHT11温湿度传感器模块,还需要在 阿里云上注册账号。接线看我上一个文章。

二、阿里云物联网

上面这些就是创建阿里云物联网平台,接下来就是写代码

三、代码部分

main.c

/* USER CODE BEGIN Header */
/**
  ******************************************************************************
  * @file           : main.c
  * @brief          : Main program body
  ******************************************************************************
  * @attention
  *
  * Copyright (c) 2024 STMicroelectronics.
  * All rights reserved.
  *
  * This software is licensed under terms that can be found in the LICENSE file
  * in the root directory of this software component.
  * If no LICENSE file comes with this software, it is provided AS-IS.
  *
  ******************************************************************************
  */
/* USER CODE END Header */
/* Includes ------------------------------------------------------------------*/
#include "main.h"
#include "dma.h"
#include "spi.h"
#include "tim.h"
#include "usart.h"
#include "gpio.h"
#include "stdio.h"
#include "string.h"
#include "dht11.h"
#include "oled.h"
#include "cJSON.h"
#include "time_data.h"

/* Private includes ----------------------------------------------------------*/
/* USER CODE BEGIN Includes */

/* USER CODE END Includes */

/* Private typedef -----------------------------------------------------------*/
/* USER CODE BEGIN PTD */

/* USER CODE END PTD */

/* Private define ------------------------------------------------------------*/
/* USER CODE BEGIN PD */
/* USER CODE END PD */

/* Private macro -------------------------------------------------------------*/
/* USER CODE BEGIN PM */

/* USER CODE END PM */

/* Private variables ---------------------------------------------------------*/

/* USER CODE BEGIN PV */

/* USER CODE END PV */

/* Private function prototypes -----------------------------------------------*/
void SystemClock_Config(void);
int WD;
int SD;
uint8_t WIFI_Connect[64];
uint8_t FWQ_Connect[64];
uint8_t MQTT_Connect[400];
uint8_t MQTT_ClientId[252];
uint8_t MQTT_CONN[252];
uint8_t MQTT_DL[252];
uint8_t MQTT_WD[128];
uint8_t MQTT_SD[128];
/* USER CODE BEGIN PFP */

/* USER CODE END PFP */

/* Private user code ---------------------------------------------------------*/
/* USER CODE BEGIN 0 */

/* USER CODE END 0 */

/**
  * @brief  The application entry point.
  * @retval int
  */
int main(void)
{
  /* USER CODE BEGIN 1 */

  /* USER CODE END 1 */

  /* MCU Configuration--------------------------------------------------------*/

  /* Reset of all peripherals, Initializes the Flash interface and the Systick. */
  HAL_Init();

  /* USER CODE BEGIN Init */

  /* USER CODE END Init */

  /* Configure the system clock */
  SystemClock_Config();

  /* USER CODE BEGIN SysInit */

  /* USER CODE END SysInit */

  /* Initialize all configured peripherals */
  MX_GPIO_Init();
  MX_DMA_Init();
  MX_SPI1_Init();
  MX_USART1_UART_Init();
  MX_USART3_UART_Init();
  MX_TIM2_Init();
  /* USER CODE BEGIN 2 */
	DHT11_Init(); //DHT11初始化
	printf("%s\r\n","text");
	
	HAL_UART_Transmit(&huart1,(uint8_t*)AT,strlen(AT),HAL_MAX_DELAY);  //发送AT测试
	HAL_Delay(200);
	
	HAL_UART_Transmit(&huart1,(uint8_t*)WiFi_Mode,strlen(WiFi_Mode),HAL_MAX_DELAY);  //配置STA模式
	HAL_Delay(200);
	
	sprintf(WIFI_Connect,"AT+CWJAP=\"%s\",\"%s\"\r\n",ssid,pass);  //连接wifi
	HAL_UART_Transmit(&huart1,(uint8_t*)WIFI_Connect,strlen(WIFI_Connect),HAL_MAX_DELAY);
	HAL_Delay(1500);
	
	sprintf(FWQ_Connect,"AT+CIPSNTPCFG=\%d,\%d,\"%s\"\r\n",1,8,"ntp1.aliyun.com"); 
	HAL_UART_Transmit(&huart1,(uint8_t*)FWQ_Connect,strlen(FWQ_Connect),HAL_MAX_DELAY); //查询/设置时区和SNTP服务器
	HAL_Delay(300);
	
	sprintf(MQTT_Connect,"AT+MQTTUSERCFG=\%d,\%d,\"%s\",\"%s\",\"%s\",\%d,\%d,\"%s\"\r\n",0,1,"NULL","物联网平台MQTT参数中的username","物联网平台MQTT参数中的passwd",0,0,"");
	HAL_UART_Transmit(&huart1,(uint8_t*)MQTT_Connect,strlen(MQTT_Connect),HAL_MAX_DELAY);  //设置MQTT用户的属性 AT+MQTTUSERCFG=<LinkID>,<scheme>,<"client_id">,<"username">,<"password">,<cert_key_ID>,<CA_ID>,<"path">
	HAL_Delay(300);
	
	sprintf(MQTT_ClientId,"AT+MQTTCLIENTID=\%d,\"%s\"\r\n",0,charID);  //k11dqdmRz06.DHT11|securemode=2\,signmethod=hmacsha256\,timestamp=1712478216024|
	HAL_UART_Transmit(&huart1,(uint8_t*)MQTT_ClientId,strlen(MQTT_ClientId),HAL_MAX_DELAY); 
	HAL_Delay(300);
	
	sprintf(MQTT_CONN,"AT+MQTTCONN=\%d,\"%s\",\%d,\%d\r\n",0,"iot-06z00dg5d86ynoc.mqtt.iothub.aliyuncs.com",1883,1); 
	HAL_UART_Transmit(&huart1,(uint8_t*)MQTT_CONN,strlen(MQTT_CONN),HAL_MAX_DELAY); 
	HAL_Delay(1000);
	
	sprintf(MQTT_DL,"AT+MQTTSUB=\%d,\"%s\",\%d\r\n",0,"/k11dqdmRz06/DHT11/user/get",1);  //顶阅阿里云物联网的DHT11
	HAL_UART_Transmit(&huart1,(uint8_t*)MQTT_DL,strlen(MQTT_DL),HAL_MAX_DELAY); 
	HAL_Delay(1000);
	
	
	
	//HAL_UART_Transmit(&huart1,(uint8_t*)mqtt_tc,strlen(mqtt_tc),HAL_MAX_DELAY);  //退出
	//HAL_Delay(200);
  /* USER CODE END 2 */

  /* Infinite loop */
  /* USER CODE BEGIN WHILE */
  while (1)
  {
		
		
		uint8_t res=DHT11_Read_Data(&temperature,&humidity); 
		if(res==0){
			DHT11_Read_Data(&temperature,&humidity);
			WD=temperature>>8;
			SD=humidity>>8;
			//OLED_ShowNum(30,24,16,WD,2);
			//OLED_ShowNum(30,44,16,SD,2);
		  //OLED_Refresh();
			printf("DHT11 temperature=%d.%d \r\n",temperature>>8,temperature&0xff);
			printf("DHT11 humidity=%d.%d%%\r\n",humidity>>8,humidity&0xff);
			
			sprintf(MQTT_WD,"AT+MQTTPUB=\%d,\"%s\",\"{\\\"params\\\":{\\\"Humi\\\":\%d}}\",\%d,\%d\r\n",0,"/sys/k11dqdmRz06/DHT11/thing/event/property/post",SD,0,0); 
			HAL_UART_Transmit(&huart1,(uint8_t*)MQTT_WD,strlen(MQTT_WD),HAL_MAX_DELAY); 
			HAL_Delay(300);
	
			sprintf(MQTT_SD,"AT+MQTTPUB=\%d,\"%s\",\"{\\\"params\\\":{\\\"temp\\\":\%d}}\",\%d,\%d\r\n",0,"/sys/k11dqdmRz06/DHT11/thing/event/property/post",WD,0,0); 
			HAL_UART_Transmit(&huart1,(uint8_t*)MQTT_SD,strlen(MQTT_SD),HAL_MAX_DELAY); 
			HAL_Delay(300);
			
			HAL_GPIO_WritePin(LED_GPIO_Port,LED_Pin,GPIO_PIN_SET);
			HAL_Delay(5000);  
		}
		
		
    /* USER CODE END WHILE */

    /* USER CODE BEGIN 3 */
  }
  /* USER CODE END 3 */
}

/**
  * @brief System Clock Configuration
  * @retval None
  */
void SystemClock_Config(void)
{
  RCC_OscInitTypeDef RCC_OscInitStruct = {0};
  RCC_ClkInitTypeDef RCC_ClkInitStruct = {0};

  /** Initializes the RCC Oscillators according to the specified parameters
  * in the RCC_OscInitTypeDef structure.
  */
  RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSE;
  RCC_OscInitStruct.HSEState = RCC_HSE_ON;
  RCC_OscInitStruct.HSEPredivValue = RCC_HSE_PREDIV_DIV1;
  RCC_OscInitStruct.HSIState = RCC_HSI_ON;
  RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;
  RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSE;
  RCC_OscInitStruct.PLL.PLLMUL = RCC_PLL_MUL9;
  if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK)
  {
    Error_Handler();
  }

  /** Initializes the CPU, AHB and APB buses clocks
  */
  RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK
                              |RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2;
  RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;
  RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
  RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV2;
  RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1;

  if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_2) != HAL_OK)
  {
    Error_Handler();
  }
}

/* USER CODE BEGIN 4 */

/* USER CODE END 4 */

/**
  * @brief  This function is executed in case of error occurrence.
  * @retval None
  */
void Error_Handler(void)
{
  /* USER CODE BEGIN  Error_Handler_Debug */
  /* User can add his own implementation to report the HAL error return state */
  __disable_irq();
  while (1)
  {
  }
  /* USER CODE END Error_Handler_Debug */
}

#ifdef  USE_FULL_ASSERT
/**
  * @brief  Reports the name of the source file and the source line number
  *         where the assert_param error has occurred.
  * @param  file: pointer to the source file name
  * @param  line: assert_param error line source number
  * @retval None
  */
void assert_failed(uint8_t *file, uint32_t line)
{
  /* USER CODE BEGIN 6 */
  /* User can add his own implementation to report the file name and line number,
     ex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */
  /* USER CODE END 6 */
}
#endif /* USE_FULL_ASSERT */

main.h

/* USER CODE BEGIN Header */
/**
  ******************************************************************************
  * @file           : main.h
  * @brief          : Header for main.c file.
  *                   This file contains the common defines of the application.
  ******************************************************************************
  * @attention
  *
  * Copyright (c) 2024 STMicroelectronics.
  * All rights reserved.
  *
  * This software is licensed under terms that can be found in the LICENSE file
  * in the root directory of this software component.
  * If no LICENSE file comes with this software, it is provided AS-IS.
  *
  ******************************************************************************
  */
/* USER CODE END Header */

/* Define to prevent recursive inclusion -------------------------------------*/
#ifndef __MAIN_H
#define __MAIN_H
#define AT "AT\r\n"
#define WiFi_Mode "AT+CWMODE=1\r\n"
#define ssid "homi"
#define pass "xhp5544671"
#define charID "k11dqdmRz06.DHT11|securemode=2\\,signmethod=hmacsha256\\,timestamp=1712478216024|"
#define mqtt_tc "AT+MQTTCLEAN=0\r\n"
#ifdef __cplusplus
extern "C" {
#endif

/* Includes ------------------------------------------------------------------*/
#include "stm32f1xx_hal.h"

/* Private includes ----------------------------------------------------------*/
/* USER CODE BEGIN Includes */

/* USER CODE END Includes */

/* Exported types ------------------------------------------------------------*/
/* USER CODE BEGIN ET */

/* USER CODE END ET */

/* Exported constants --------------------------------------------------------*/
/* USER CODE BEGIN EC */

/* USER CODE END EC */

/* Exported macro ------------------------------------------------------------*/
/* USER CODE BEGIN EM */

/* USER CODE END EM */

/* Exported functions prototypes ---------------------------------------------*/
void Error_Handler(void);

/* USER CODE BEGIN EFP */

/* USER CODE END EFP */

/* Private defines -----------------------------------------------------------*/
#define LED_Pin GPIO_PIN_2
#define LED_GPIO_Port GPIOA
#define DHT11_DATA_Pin GPIO_PIN_3
#define DHT11_DATA_GPIO_Port GPIOA
#define OLED_CS_Pin GPIO_PIN_4
#define OLED_CS_GPIO_Port GPIOA
#define OLED_RES_Pin GPIO_PIN_0
#define OLED_RES_GPIO_Port GPIOB
#define OLED_DC_Pin GPIO_PIN_1
#define OLED_DC_GPIO_Port GPIOB
/* USER CODE BEGIN Private defines */

/* USER CODE END Private defines */

#ifdef __cplusplus
}
#endif

#endif /* __MAIN_H */

实验结果

### 回答1: 要让STM32ESP8266连接阿里云,需要先了解阿里云物联网平台和相关的API接口。然后根据具体的应用场景需求,选择合适的协议和通信方式进行连接。具体可以采用MQTT或者HTTP协议进行连接,由此实现双向的数据传输。 首先,在STM32ESP8266中需要增加ESP8266的AT指令,将其作为WiFi模块使用,然后在此基础上进行网络配置和连接,获取SSID和密码信息等。然后基于MQTT或者HTTP协议进行连接,这两种协议都可以在阿里云IoT平台上实现。 使用MQTT协议进行连接,需要在STM32ESP8266中进行配置,包括服务器地址,端口号,客户端ID等信息。然后建立连接,发布或者订阅主题消息即可。 使用HTTP协议进行连接,需要在STM32ESP8266上进行HTTP请求,获取授权信息和TOKEN,然后调用阿里云提供的API接口来实现信息的发送和接收。 以上是STM32ESP8266连接阿里云的一些关键思路和步骤,具体还需要根据具体的需求进行详细的实现和调试。 ### 回答2: STM32是一款低功耗高性能的单片微控制器,而ESP8266是一款低成本的Wi-Fi模组,它们可以联合使用来连接阿里云。 首先,你需要准备一台带有Wi-Fi模块供应商的STM32开发板,例如STMicroelectronics提供的Nucleo-F401RE,以及一台ESP8266 Wi-Fi模组。你还需要在阿里云上创建一个IoT Hub实例并为其生成证书。 接下来,你需要下载阿里云的SDK,该SDK支持C语言和STM32平台。将SDK包中的文件添加到您的工程中,并包含其头文件。 然后,在您的工程中设置Wi-Fi连接信息,包括SSID和密码。根据您的需求,您可以选择使用TCP或UDP协议,以及MQTT客户端进行连接和通信。 在向阿里云发送消息之前,您需要先使用证书验证自己的身份,并将证书和密钥文件添加到您的工程中。然后,您可以使用阿里云提供的API来发送和接收MQTT消息。 当您成功连接阿里云IoT Hub并成功发送消息时,您可以在控制台中查看数据并将其用于您的应用程序。 在整个过程中,您需要确保您的代码按照阿里云SDK的指导进行编写,并且正确设置了Wi-Fi连接信息和证书。这将帮助您在不久的将来轻松地实现自己的IoT应用程序。 ### 回答3: STM32ESP8266作为微控制器和Wi-Fi模块组合,可以联合运作并连接阿里云。概括地说,需要进行以下几步: 1. 准备硬件 网上购买STM32ESP8266开发板,将它们连接在一起。需要确保它们之间的连接是准确的,例如使用串行通信,确保引脚连接正确。 2. 搭建开发环境 需要安装ST-Link/V2驱动、Keil或者IAR等开发环境。ESP8266可以使用AT指令模式进行编程,也可以使用Lua语言进行编程。 3. 实现连接阿里云 (1)首先,注册阿里云账号并创建物联网实例。 (2)在阿里云后台创建设备,并获得设备的三元组信息(Device Name、ProductKey、Device Secret)。 (3)在STM32ESP8266中,添加连接阿里云云平台所需要的支持代码,例如接入SDK等。 (4)编写代码,将STM32ESP8266连接到Wi-Fi网络并连接阿里云云平台。具体步骤包括: a. 将ESP8266设置为STA模式或AP模式,分别连接到Wi-Fi网络或者创建一个Wi-Fi热点。 b. 设置阿里云物联网平台的API密钥。 c. 在STM32中,编写代码将设备信息(Device Name、ProductKey、Device Secret)从芯片里读取出来。 d. 在ESP8266中编写代码将三元组信息加入MQTT连接参数,并连接到云端。 4. 通过阿里云平台进行消息传递 连接成功后,STM32ESP8266可以通过阿里云平台来进行双向数据传递。例如,STM32可以向阿里云发送传感器数据,阿里云会将数据转发给ESP8266ESP8266再将数据发送到远程设备或者APP上。 这就是STM32ESP8266连接阿里云的主要流程。由于每个项目的要求不同,需要根据实际环境和需求来优化代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小小萌星

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值