esp8266上传数据到网页

您所在的位置:网站首页 esp8266上传数据到数据库 esp8266上传数据到网页

esp8266上传数据到网页

#esp8266上传数据到网页| 来源: 网络整理| 查看: 265

系列文章目录

第一章ESP8266的java软件仿真测试 第二章ESP8266硬件与软件测试 第三章ESP8266客户端与Java后台服务器联调 第四章ESP8266客户端与JavaWeb服务器联调 第五章ESP8266客户端与JavaWeb服务器网页联调

文章目录 系列文章目录前言一、物联网单片机客户端与网站结合是什么?二、使用步骤1.下载代码搭建开发环境2.读入数据 总结

前言

daodanjishui物联网核心原创技术之物联网服务器网站部署

一、物联网单片机客户端与网站结合是什么?

本文在第四章介绍了ESP8266客户端与JavaWeb服务器联调,当时的服务器还没有主页,只是在后台控制台打印出单片机传输过来的温湿度而已,这就是第四章设计的缺点所在。 那么这次设计将会把JavaWeb服务器后台接收到的数据放到主页上显示出来,能访问到服务器主页的浏览器都能远程查询到单片机采集的温湿度数据。 下面是效果展示: (1)硬件部署 STM32+DHT11+ESP8266 (2)JavaWeb服务器网页显示单片机采集的温湿度数据,属于私人云服务器(点击“发送”按钮才触发查询)

服务器网页显示数据 上图中可以看出是一个eclipse部署javaweb私人服务器;网页首页显示一张图片和控制按钮和显示区域;箭头1是私人服务器的网络访问地址;箭头2是点击发送按钮之后在网页中显示出来的dht11的采集的数据,还有采集数据的时间;箭头3是终端后台打印的dht数据。所以这套程序完全可以打通硬件、网络、前端和后端技术。后期将会推出自动刷新和配备手机客户端专题! (3)局域网其他电脑浏览器查询结果 多个客户端查询结果 (4.0)stm32和ESP8266联调开机打印信息,tm32单片机库函数控制ESP8266配网的过程很多时候比较麻烦的。并且wifi容易断线,现在还加入了断线重连的功能,调试蛮久才成功了,因为这个单片机是要链接我私人服务器的!配网过程如下图所示: 在这里插入图片描述

(4.1)stm32单片机串口调试助手调试信息打印 串口打印信息

(5)私人服务器工程目录和服务器后台打印数据 服务器后台打印数据

二、使用步骤 1.下载代码搭建开发环境

代码和教程的详细下载地址:https://www.cirmall.com/circuit/18567/ 点击跳转到目的地

部分采集数据代码如下(示例):

#include “bsp_dht11.h” #include “delay.h” /*

函数名:DHT11_GPIO_Config

描述 :配置DHT11用到的I/O口

输入 :无

输出 :无 */ void DHT11_GPIO_Config(void) { /定义一个GPIO_InitTypeDef类型的结构体/ GPIO_InitTypeDef GPIO_InitStructure;

/开启DHT11_PORT的外设时钟/ RCC_APB2PeriphClockCmd(DHT11_CLK, ENABLE);

/选择要控制的DHT11_PORT引脚/ GPIO_InitStructure.GPIO_Pin = DHT11_PIN;

/设置引脚模式为通用推挽输出/ GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;

/*设置引脚速率为50MHz */ GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;

/调用库函数,初始化DHT11_PORT/ GPIO_Init(DHT11_PORT, &GPIO_InitStructure);

/* 拉高GPIOB10 */ GPIO_SetBits(DHT11_PORT, DHT11_PIN); }

/*

函数名:DHT11_Mode_IPU

描述 :使DHT11-DATA引脚变为上拉输入模式

输入 :无

输出 :无 */ static void DHT11_Mode_IPU(void) { GPIO_InitTypeDef GPIO_InitStructure;

/*选择要控制的DHT11_PORT引脚*/

GPIO_InitStructure.GPIO_Pin = DHT11_PIN;

/*设置引脚模式为浮空输入模式*/

GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPU ;

/调用库函数,初始化DHT11_PORT/ GPIO_Init(DHT11_PORT, &GPIO_InitStructure); }

/*

函数名:DHT11_Mode_Out_PP

描述 :使DHT11-DATA引脚变为推挽输出模式

输入 :无

输出 :无 */ static void DHT11_Mode_Out_PP(void) { GPIO_InitTypeDef GPIO_InitStructure;

/*选择要控制的DHT11_PORT引脚*/

GPIO_InitStructure.GPIO_Pin = DHT11_PIN;

/设置引脚模式为通用推挽输出/ GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;

/*设置引脚速率为50MHz */ GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;

/调用库函数,初始化DHT11_PORT/ GPIO_Init(DHT11_PORT, &GPIO_InitStructure); }

/*

从DHT11读取一个字节,MSB先行 */ static uint8_t Read_Byte(void) { uint8_t i, temp=0;

for(i=0;i /轮询直到从机发出 的80us 低电平 响应信号结束/ while(DHT11_DATA_IN()==Bit_RESET);

/*轮询直到从机发出的 80us 高电平 标置信号结束*/ while(DHT11_DATA_IN()==Bit_SET); /*开始接收数据*/ DHT11_Data->humi_int= Read_Byte(); DHT11_Data->humi_deci= Read_Byte(); DHT11_Data->temp_int= Read_Byte(); DHT11_Data->temp_deci= Read_Byte(); DHT11_Data->check_sum= Read_Byte(); /*读取结束,引脚改为输出模式*/ DHT11_Mode_Out_PP(); /*主机拉高*/ DHT11_DATA_OUT(HIGH); /*检查读取的数据是否正确*/ if(DHT11_Data->check_sum == DHT11_Data->humi_int + DHT11_Data->humi_deci + DHT11_Data->temp_int+ DHT11_Data->temp_deci) return SUCCESS; else return ERROR;

} else { return ERROR; } }

/*******END OF FILE/

2.读入数据

部分代码如下(示例):

private void sendMessages(HttpServletRequest request, HttpServletResponse response) {//单片机发送温湿度给服务器 ServletContext application=getServletContext();//获取application System.out.println(“进入sendMessages方法”); response.setContentType(“text/html;charset=UTF-8”);//设置响应内容和编码方式 String user=request.getParameter(“user”);//昵称 String speak=request.getParameter(“speak”);//说话内容 mymessage="["+user+"]say:"+speak;//给单片机的 System.out.println(mymessage); String message="["+user+"]say:"+speak;//组合说话内容 application.setAttribute(“message”, mymessage);//将聊天内容保存到application try { response.getWriter().println(mymessage); } catch (IOException e) { e.printStackTrace(); } }

总结

首先esp8266无线连接到局域网无线热点和局域网javaweb服务器,然后定时上传dht11数据到服务器,最后用户登录浏览器输入网址点击发送按钮就可以查询到dht数据了。 这次设计将会把JavaWeb服务器后台接收到的数据放到主页上显示出来,能访问到服务器主页的浏览器都能远程查询到单片机采集的温湿度数据。单片机客户端定时上报数据,服务器接受单片机客户端的请求并且将数据存起来,浏览器客户端随时查询数据,服务器再响应浏览器客户端的请求把数据返回给浏览器显示出来。 服务器逻辑设计精妙和严谨,客户端联网设计细腻,系统运行良好,断线重连,stm32运行稳定,ESP8266无线通信速度够快,总的来说适合作为物联网初级参数采集系统的雏形,daodanjishui核心原创DIY值得再次期待。



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3