admin管理员组

文章数量:1122847


  • 本系列博客学习由非官方人员 半颗心脏 潜心所力所写,不做开发板。仅仅做个人技术交流分享,不做任何商业用途。如有不对之处,请留言,本人及时更改。
序号SDK版本内容链接
1nonos2.0搭建开发环境,开始一个“hellow world”串口打印。点我访问
2nonos2.0利用GPIO开始使用按钮点亮你的“第一盏灯。点我访问
3nonos2.0利用 "软件定时器 " 定时0.5秒闪烁点亮一盏LED。点我访问
4nonos2.0用PWM控制一盏LED的亮度变化。点我访问
5nonos2.0SDK高级使用之封装Post与Get请求云端,拿到“天气预报信息”。点我访问
6nonos2.0了解 SmartConfig与Airkiss一键配网,给8266配网上云端。无需把wifi名字密码写在固件里。点我访问
7nonos2.0了解 softAP热点配网模式原理,仿“机智云”定义自己的热点配网模式协议。点我访问
8nonos2.0你要找的8266作为UDP、TCP客户端或服务端的角色通讯,都在这了。点我访问
9nonos2.0[小实战上篇]Windows系统搭建8266的本地Mqtt服务器,局域网点亮一盏LED灯。点我访问
10nonos2.0[小实战下篇]Windows系统搭建8266的本地Mqtt服务器,局域网点亮一盏LED灯。点我访问
11rtos2.0接入阿里智能,点亮一盏LED灯,期待天猫精灵语音控制的不约而至!点我访问
12nonos2.0图文并茂学习阿里云主机搭建8266MQTT服务器,实现移动网络远程控制一盏LED。点我访问
13nonos2.0动手做个8266毕设小案例,smartConfig + MQTT协议轻松实现远程控制一盏LED。点我访问
14rtos2.0FreeRtos系统学习的正确姿势 ------ 环境搭建、烧录。点我访问
15rtos2.0接入阿里云平台非阿里智能的SDS服务,点亮一盏LED灯。点我访问
16nonos2.0基于Nonos移植红外线H1838,实现红外遥控器配网,远程控制一盏灯。点我访问
17nonos2.0esp8266自研的快速上电开关五次 (开-关为一次) ,无需按键触发则8266进去一键配网模式。点我访问
18nonos2.0基于NONOS 实现 OTA 远程升级,实现无线“ 热修复 ”升级固件程序。点我访问
19nonos2.0驱动 ds18b20、dht11 温湿度传感器,采集温湿度传感器到服务器。点我访问
20nonos2.0深入学习esp8266的esp now模式,仿机智云做一个小网关,实现无需网络下轻松彼此连接通讯交互数据。点我访问
21nonos2.0浅谈 esp8266 如何在本地局域网网络情况下实现最大效率地和前端实现数据交互。点我访问
22nonos2.0esp8266的工程如何添加第三方静态库文件以及如何自定义文件夹,聊聊那些makeFile的事点我访问
23nonos2.0再来一波 esp8266 基于 freeRtos系统连接自己私有的服务器实现OTA远程升级,接触下 lwip的基本知识。点我访问
24nonos2.0渗透学习回顾下esp8266的外置spi芯片25q系列,熟悉8266代码块在其的分布,得心应手放置图片或其他资料。点我访问
25rtos2.0深聊下esp8266的串口 Uart 通讯中断编程,为您准备好了 NONOS 版本 和 RTOS 系统的串口驱动文件。点我访问
26nonos2.0RTOS分析 MQTT 实现过程,实现移植 MQTT协议在 esp8266 rtos实时系统,可断线重连。点我访问
27rtos3.0跟紧脚步,用VisualStudio Code开发 esp8266 rtos SDK v3.0版本,全新的 idf 框架,节省内存模块化开发。点我访问
28rtos3.0教你轻松自如使用cJson在乐鑫 esp8266 如何解析一段json数据以及如何生成一段json数据。点我访问
29rtos3.0百万条消息免费之使用TCP直连模式MQTT协议接入阿里云物联网平台,支持私家服务器对接支持阿里云规则引擎。点我访问
30rtos3.0SDK编程使用 IIC总线驱动 0.96寸的OLED显示屏,显示天气预报信息。点我访问
31rtos3.0当esp8266遇到 Html,该怎么内置网页控制设备,理清内置网页的实现过程,实现无需路由器手机也可以控制esp8266。点我访问
32rtos3.0细聊HmacMD5的加密方法带来的安全性,并实践在esp8266上,最大保障传输的过程的信息的安全性。点我访问
33rtos3.0如何优雅地像乐鑫原厂封装esp8266底层寄存器的逻辑思维,做成自己的静态库库文件,让第三方人使用?点我访问
34nonos3.0编程使用 SPI 驱动基于Max7219芯片的八位数码管,显示日期信息。点我访问
35nonos3.0借助机智云平台做一个商业化的七彩RGB灯泡可调整体方案项目,炫彩夺目高大尚。点我访问
36rtos3.0认识Rtos 3.0 sdk 工程结构,如何向esp-idf工程靠近的,如何自定义头文件编译?点我访问
37rtos3.0你要找的基本外设功能都在这里了,包括Gpio、Pwm 和 Uart 接口使用。点我访问
38rtos3.0一篇文章带你搞掂存储技术 NVS 的认识和使用,如何利用NVS保存整型、字符串、数组以及结构体。点我访问
39rtos3.0带你捋一捋市面上的微信公众号配网智能设备 esp8266 并绑定设备的过程,移植并成功实现在 esp8266 rtos3.1 sdk。点我访问
40rtos3.0基于乐鑫idf框架,研究出超稳定、掉线重连、解决内存泄露问题的Mqtt框架!支持esp8266和esp32!点我访问
41rtos3.0esp8266-12模块基于rtos3.1版本ota功能远程空中升级固件,官网基础之上增加dns域名解析!点我访问
42rtos3.0我又来了,基于rtos3.0版本 SDK编程 SPI 驱动 ws2812b 七彩灯,代码全部开源奉献给你们!点我访问
43rtos3.0基于rtos3.0版本扫描周围获取附近可用的 Wi-Fi 热点路由器信息,同样适合esp32。点我访问
44rtos3.0整理分享那些我在项目中常用的esp8266 rtos3.0版本的常见驱动,Button按键长短按、PWM平滑调光等。点我访问
45rtos3.0内置仅1M的Esp8285,如何攻破最棘手的OTA问题,大大节省资源成本开发产品点我访问
46rtos3.0详细分析Esp8266上电信息打印的数据,如何做到串口通讯上电不乱码打印;点我访问
47rtos3.0无需外网,如何实现在本地局域网与控制端做数据交换的一些开发经验;点我访问
48rtos3.0迟来的1024程序员祝福,开源分享一个驱动 ds18b20 获取温度的工程。点我访问
49rtos3.2aliyun sdk 直连接入阿里云物联网平台,实现天猫精灵找队友零配网功能和语音控制。点我访问
持续更新,欢迎关注我,QQ群讨论群:434878850

  • 很多人怎么联系我一起学习进步,下面打个小小公告和干货无偿分享:

玩转esp8266带你飞、加群付费QQ群,提高门槛,不喜的朋友勿喷勿加:434878850
esp8266源代码免费学习汇总(持续更新,欢迎star):https://github/xuhongv/StudyInEsp8266
esp32源代码免费学习汇总(持续更新,欢迎star):https://github/xuhongv/StudyInEsp32

目录:

文章目录

    • 目录:
    • @[toc]
      • 一、前言。
        • 1.3、电路图:最小系统就行。因为不需要物理按键触发配网:
      • 二、理论知识 。
        • 2.1 、 esp8266从联网到云端取数据的原理。
        • 2.2 、原理流程大概都懂了。但是重要的是搞硬件的电子爱好者可能不懂 **啥是Post请求和Get请求**,好吧!我再画一个图:
        • 2.3 、既然请求方式都懂了,那么我们的8266是怎么做到请求数据呢?好吧!我再再画一个图:
      • 三、上代码!
        • 3.1 写头文件 my_http.h"的实现C文件。**用于剖析URL,定义post请求或get请求。**
        • 3.2、写头文件client.h的实现C文件。**用于配置本地端口、连接服务器**
        • 3.3 程序入口,user_main.c。
      • 4、关于服务器的选择与怎么看接口使用。
        • 4.1、这个我使用的是心知天气,不是卖广告,***不喜勿喷!!**

一、前言。


####1.1、 由于本篇博文理论多于代码,大家要耐心看下去哦。先上效果图:



####1.2、我还是复制过来吧,图片看的模糊:


GM�X匑IeI旝E爻釩Q@娈]_[窜N臫瀺郹\�%aHP@i薱hFa咤爾@G阝吿TQ征枀H歃Ea蹷�aHP@iI塒@娈a繲氣厛TQ睁邊瞃a蹷�uJQ@i嫂Q@娈q萒陉吺Y蓥迏H鋂膄�a\�� *惣謱滯鮂


 ----- PB  start -----  
api.seniverse/v3/weather/daily.json?key=rrpd2zmqkpwlsckt&location=guangzhou&language=en&unit=c&start=0&days=3
 ----- PB next -----  
/v3/weather/daily.json?key=rrpd2zmqkpwlsckt&location=guangzhou&language=en&unit=c&start=0&days=3
 ----- PB end -----  

 ----- PB=true -----  
api.seniverse

 ----- 请求数据开始----- 
GET /v3/weather/daily.json?key=rrpd2zmqkpwlsckt&location=guangzhou&language=en&unit=c&start=0&days=3 HTTP/1.1
Content-Type: text/html;charset=utf-8
Accept: */*
Host: api.seniverse
Connection: Keep-Alive


 -----请求数据结束-----  
 
发送数据成功!
 
 ----- 开始接受数据----- 
 
 HTTP/1.1 200 OK
Date: Tue, 28 Nov 2017 08:23:45 GMT
Content-Type: application/json; charset=utf-8
Content-Length: 900
Connection: keep-alive
Cache-Control: no-cache
Pragma: no-cache
Expires: -1

{"results":[{"location":{"id":"WS0E9D8WN298","name":"Guangzhou","country":"CN","path":"Guangzhou,Guangzhou,Guangdong,China","timezone":"Asia/Shanghai","timezone_offset":"+08:00"},"daily":[{"date":"2017-11-28","text_day":"Cloudy","code_day":"4","text_night":"Overcast","code_night":"9","high":"25","low":"18","precip":"","wind_direction":"CLM","wind_direction_degree":"","wind_speed":"10","wind_scale":"2"},{"date":"2017-11-29","text_day":"Overcast","code_day":"9","text_night":"Light rain","code_night":"13","high":"25","low":"16","precip":"","wind_direction":"CLM","wind_direction_degree":"","wind_speed":"10","wind_scale":"2"},{"date":"2017-11-30","text_day":"Light rain","code_day":"13","text_night":"Light rain","code_night":"13","high":"21","low":"14","precip":"","wind_direction":"CLM","wind_direction_degree":"","wind_speed":"10","wind_scale":"2"}],"last_update":"2017-11-28T11:00:00+08:00"}]}

 -----结束接受数据-----  
 
  断开连接成功!
 

1.3、电路图:最小系统就行。因为不需要物理按键触发配网:


二、理论知识 。


2.1 、 esp8266从联网到云端取数据的原理。


2.2 、原理流程大概都懂了。但是重要的是搞硬件的电子爱好者可能不懂 啥是Post请求和Get请求,好吧!我再画一个图:


2.3 、既然请求方式都懂了,那么我们的8266是怎么做到请求数据呢?好吧!我再再画一个图:


三、上代码!


3.1 写头文件 my_http.h"的实现C文件。用于剖析URL,定义post请求或get请求。


#include "my_http.h"
#include "c_types.h"
#include "client.h"

//剖析URL
void ICACHE_FLASH_ATTR http_parse_request_url(char *URL, char *host,char *filename, unsigned short *port) {

	char *PA;
	char *PB;

	memset(host, 0, sizeof(host));
	memset(filename, 0, sizeof(filename));

	*port = 0;

	if (!(*URL)){
		uart0_sendStr("\r\n ----- URL return -----  \r\n");
		return;
	}

	PA = URL;
	if (!strncmp(PA, "http://", strlen("http://"))) {
		PA = URL + strlen("http://");
	} else if (!strncmp(PA, "https://", strlen("https://"))) {
		PA = URL + strlen("https://");
	}

	PB = strchr(PA, '/');
	if (PB) {
		uart0_sendStr("\r\n ----- PB=true -----  \r\n");
		memcpy(host, PA, strlen(PA) - strlen(PB));
		if (PB + 1) {
			memcpy(filename, PB + 1, strlen(PB - 1));
			filename[strlen(PB) - 1] = 0;
		}
		host[strlen(PA) - strlen(PB)] = 0;

		uart0_sendStr(host,strlen(host));

	} else {
		uart0_sendStr("\r\n ----- PB=false -----  \r\n");
		memcpy(host, PA, strlen(PA));
		host[strlen(PA)] = 0;
		uart0_sendStr(host,strlen(host));
	}
	PA = strchr(host, ':');
	if (PA){
		*port = atoi(PA + 1);
	}else{
		*port = 80;
	}
}

//寻找DNS解析,并且配置
void ICACHE_FLASH_ATTR user_esp_dns_found(const char *name, ip_addr_t *ipaddr,void *arg) {

	struct ip_info info;
	wifi_get_ip_info(STATION_IF, &info);
	my_station_init(ipaddr, &info.ip, port);

}

//定义Get请求的实现
void ICACHE_FLASH_ATTR startHttpQuestByGET(char *URL){
	struct ip_addr addr;
	memset(buffer,0,1024);
	http_parse_request_url(URL,host,filename,&port);
	os_sprintf(buffer,GET,filename,host);
	espconn_gethostbyname(&user_tcp_conn,host, &addr,
	user_esp_dns_found);
}


//定义Post请求的实现
void ICACHE_FLASH_ATTR startHttpQuestByPOST(char *URL,char *method,char *postdata){
	struct ip_addr addr;
	memset(buffer,0,1024);
	http_parse_request_url(URL,host,filename,&port);
	os_sprintf(buffer,POST,filename,strlen(postdata),host,postdata);
	espconn_gethostbyname(&user_tcp_conn,host, &addr,
	user_esp_dns_found);
}

3.2、写头文件client.h的实现C文件。用于配置本地端口、连接服务器

#include "client.h"
#include "iconv.h"
#include "stdio.h"
#include "string.h"

//成功接收到服务器返回数据函数
void ICACHE_FLASH_ATTR user_tcp_recv_cb(void *arg, char *pdata,
		unsigned short len) {
	uart0_sendStr("\r\n ----- 开始接受数据----- \r\n ");
	uart0_tx_buffer(pdata, strlen(pdata));
	uart0_sendStr("\r\n -----结束接受数据-----  \r\n ");

}

//发送数据到服务器成功的回调函数
void ICACHE_FLASH_ATTR user_tcp_sent_cb(void *arg) {
	uart0_sendStr("发送数据成功!\r\n ");
}

//断开服务器成功的回调函数
void ICACHE_FLASH_ATTR user_tcp_discon_cb(void *arg) {
	uart0_sendStr("断开连接成功!\r\n ");
}

//连接失败的回调函数,err为错误代码
void ICACHE_FLASH_ATTR user_tcp_recon_cb(void *arg, sint8 err) {
	uart0_sendStr("连接错误,错误代码为%d\r\n", err);
	espconn_connect((struct espconn *) arg);
}

//成功连接到服务器的回调函数
void ICACHE_FLASH_ATTR user_tcp_connect_cb(void *arg) {
	struct espconn *pespconn = arg;
	espconn_regist_recvcb(pespconn, user_tcp_recv_cb);
	espconn_regist_sentcb(pespconn, user_tcp_sent_cb);
	espconn_regist_disconcb(pespconn, user_tcp_discon_cb);

	uart0_sendStr("\r\n ----- 请求数据开始----- \r\n");
	uart0_tx_buffer(buffer, strlen(buffer));
	uart0_sendStr("\r\n -----请求数据结束-----  \r\n");

	espconn_sent(pespconn, buffer, strlen(buffer));

}
void ICACHE_FLASH_ATTR my_station_init(struct ip_addr *remote_ip,
		struct ip_addr *local_ip, int remote_port) {
	//配置
	user_tcp_conn.type = ESPCONN_TCP;
	user_tcp_conn.state = ESPCONN_NONE;
	user_tcp_conn.proto.tcp = (esp_tcp *) os_zalloc(sizeof(esp_tcp));
	os_memcpy(user_tcp_conn.proto.tcp->local_ip, local_ip, 4);
	os_memcpy(user_tcp_conn.proto.tcp->remote_ip, remote_ip, 4);
	user_tcp_conn.proto.tcp->local_port = espconn_port();
	user_tcp_conn.proto.tcp->remote_port = remote_port;
	//注册
	espconn_regist_connectcb(&user_tcp_conn, user_tcp_connect_cb);
	espconn_regist_reconcb(&user_tcp_conn, user_tcp_recon_cb);
	//连接服务器
	espconn_connect(&user_tcp_conn);
}


3.3 程序入口,user_main.c。

#include "driver/uart.h"
#include "user_main.h"

//连接路由器的定时器
os_timer_t checkTimer_wifistate;

void Check_WifiState(void) {
	uint8 getState;
	getState = wifi_station_get_connect_status();

	//如果状态正确,证明已经成功连接到路由器
	if (getState == STATION_GOT_IP) {
	
		os_printf("WIFI连接成功!把连接路由器的定时器关闭!");
		os_timer_disarm(&checkTimer_wifistate);
		os_timer_disarm(&connect_timer);

		uint8 status = wifi_station_get_connect_status();
		if (status == STATION_GOT_IP) {
			uart0_sendStr("WIFI连接成功!开始请求数据!");
			startHttpQuestByGET(
					"https://api.seniverse/v3/weather/daily.json?key=rrpd2zmqkpwlsckt&location=guangzhou&language=en&unit=c&start=0&days=3");
			return;
		}
	}

}


void user_init() {

	uart_init(57600, 57600);
	wifi_set_opmode(0x01); //设置为STATION模式
	struct station_config stationConf;
	os_strcpy(stationConf.ssid, "TP-LINK_AliYun");	  //改成你自己的   路由器的用户名
	os_strcpy(stationConf.password, "aliyun_123456"); //改成你自己的   路由器的密码
	wifi_station_set_config(&stationConf); //设置WiFi station接口配置,并保存到 flash
	wifi_station_connect(); //连接路由器

	os_timer_disarm(&checkTimer_wifistate); //取消定时器定时
	os_timer_setfn(&checkTimer_wifistate, (os_timer_func_t *) Check_WifiState,
	NULL); //设置定时器回调函数
	os_timer_arm(&checkTimer_wifistate, 500, true); //启动定时器,单位:毫秒500
	
}




4、关于服务器的选择与怎么看接口使用。


4.1、这个我使用的是心知天气,不是卖广告,*不喜勿喷!!

接口:https://www.seniverse/doc#daily


[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-4XTme5nP-1572071206426)(https://img-blog.csdn/20171128175707814?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQveGg4NzAxODkyNDg=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)]


Demo: https://github/xuhongv/StudyInEsp8266/tree/master/6_PostAndGet

本文标签: 之旅云端天气预报高级信息