8.物联网LWIP,简要介绍http(超文本,URL),html(css,ajax),web实现打开灯

一。HTTP详解

1.超文本:(HyperText)

(1)超文本文件彼此链接,形成网状(web),内含有超链接(Link)与各种媒体元素标记(Markup)。

(2)超文本文件彼此链接使用URL表示。(下面解释URL)

(3)常见超文本格式是超文本标记语言HTML。(下面解释HTML,代码)

综上:学习超文本需要了解超链接,超文本标记语言

2.URL

(1)URL称为统一资源定位符Uniform Resource Locator,唯一标识万维网的某个文档。

(2)URL组成:协议+(主机+端口)+文件名

 3.HTTP

(1)工作原理

        在我看来就是建立TCP连接,客户机发送请求文档,服务器端发送响应文档。三次握手四次挥手。

(2)请求报文与响应报文(字段为ASCLL码, CRLF为回车)

 (3)请求方法

1.GET:请求读取一个Web页面

2.POST:附加一个命名资源(如Web页面)

3.DELETE:删除Web页面

4.CONNECT:用于代理服务器

5.HEAD:请求读取一个Web页面的首部

6.PUT:请求存储一个Web页面

7.TRACE:用于测试,要求服务器送回收到的请求

8.OPTION:查询特定选项

二。实验:初步使用Web超文本标记语音html

1.实验1:html

    复制下面代码到一个文件夹下,后缀改为 .html,双击打开。

<HTML><HEAD><TITLE>欢迎进入 HTML 世界</TITLE></HEAD><BODY><P>这会是一种很有趣的体验</P></BODY>
</HTML>

代码解答:

        1.大框架,<HTML> 内容 </HTML>

        2.头名称,<HEAD> 内容 </HEAD>

                <TITLE>欢迎进入 HTML 世界</TITLE>

                

        3.页面内容,<BODY> 内容 </BODY>

                <P>这会是一种很有趣的体验</P>

                 

                      

结果:

2.实验2:引入CSS 

(1)CSS作用:样式修改

(2)步骤:

创建一个文件夹,后缀名为 .html

<HTML><HEAD><TITLE>欢迎进入 HTML 世界</TITLE><style type="text/css">p{ font-size:200px;color:red;} </style></HEAD><BODY><P>这会是一种很有趣的体验</P></BODY>
</HTML>

代码解答:

        1.style样式:中间写对<BODY>中的样式处理

        2.样式中的p{}对应<BODY>中的<p>,即style中对<p></p>中数据进行样式处理

3.实验:引入javascript

(1)javascript介绍

1.javascript是互联网上最流行的脚本语言,可以用于HTML和web。

2.具体的功能包括:

  • 直接写入 HTML 输出流

  • 对事件的反应

  • 改变 HTML 内容

  • 改变 HTML 图像

  • 改变 HTML 样式

  • 验证输入

(2)步骤:

<HTML><HEAD><TITLE>欢迎进入 HTML 世界</TITLE><script type = "text/javascript">var arr = new Array();arr[0] = "1.jpg";arr[1] = "2.jpg";arr[2] = "3.jpg";var i = 0;setInterval(changeImg,1000);function changeImg(){var obj = document.getElementById("obj");obj.src = arr[i++];if(i == 3){i = 0;}}</script></HEAD><BODY><P>这会是一种很有趣的体验</P><img id = "obj" src = "1.jpg"/></BODY>
</HTML>

解释:

        1.<script type = "text/javascript"> 内容 </script>中是写HTML的动作

        2.setInterval(changeImg,1000);//使用函数,1秒运行一次
           function changeImg(){}//函数具体实现

        3.<img id = "obj" src = "1.jpg"/>命名图片的id,初始化一个属性为“src”,在javaScript中使用可以对其进行修改,这样就可以改变HTML的动作。

使用代码步骤

1.在桌面下创建

2.点击hello.html

会自己改变图片。

 三。实验三:ajax技术

1.ajax作用

        ajax主要是为了与服务器交换数据,更新部分页面内容。

2.ajax使用

(1)创建XMLHttpRequest

var xmlhttp;
if (window.XMLHttpRequest)
{//  IE7+, Firefox, Chrome, Opera, Safari 浏览器执行代码xmlhttp=new XMLHttpRequest();
}
else
{// IE6, IE5 浏览器执行代码xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
}

(2)向服务器发送请求

<GET>

xmlhttp.open("GET","/try/ajax/demo_get.php",true);
xmlhttp.send();

<POST>

xmlhttp.open("POST","/try/ajax/demo_post2.php",true);
xmlhttp.setRequestHeader("Content-type","application/x-www-form-urlencoded");
xmlhttp.send("fname=Henry&lname=Ford");

        上述GET与POST都是需要先open打开,其次send发送数据。

<异步true>

xmlhttp.onreadystatechange=function()
{if (xmlhttp.readyState==4 && xmlhttp.status==200){document.getElementById("myDiv").innerHTML=xmlhttp.responseText;}
}
xmlhttp.open("GET","/try/ajax/ajax_info.txt",true);
xmlhttp.send();

        xmlhttp.onreadystatechange=function()相当于C语言的回调函数,所以使用异步true可以像C语言中断回调一样,不需要堵塞程序。

<同步false>

xmlhttp.open("GET","/try/ajax/ajax_info.txt",false);
xmlhttp.send();
document.getElementById("myDiv").innerHTML=xmlhttp.responseText;

        同步会堵塞程序,即没有连接成功会一直在等待连接,效率差。

3.html实现

(1)基础实现

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>web 点灯</title>
<script defer="defer">function ledSwitch(string) {document.getElementById("txtState").style.backgroundColor = string;}</script>
</head><body style="background-color:black">
<font size="12" color="yellow">
<b>
<div class="text" style=" text-align:center;"><big>Web 点灯</big></div>
</b>
</font>
<br> </br>     
<div align="center" id="txtState"style="margin:auto;width:160px;height:160px;border-radius:50%;background:white;"></div>
<br> </br>
<div style=" text-align:center;">
<input type="button" value="打开" style="width:160px;height:80px;background:green;" onclick="ledSwitch('red')" />
<input type="button" value="关闭" style="width:160px;height:80px;background:red;" onclick="ledSwitch('white')" />
</div>
</body>
</html>

1.使用方法        

        复制到 .html文件中,直接运行。

2.解释

        (1)<script></script>中写函数

        (2)onclick表示按键,按下后调用script中的函数。

3.详细解释

(2)交互功能实现

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>web 点灯</title>
<script defer="defer">function ledSwitch(string) {var xmlhttp;if (window.XMLHttpRequest) {xmlhttp = new XMLHttpRequest();} else {xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");}xmlhttp.onreadystatechange = function () {if (xmlhttp.readyState == 4 && xmlhttp.status == 200) {document.getElementById("txtState").style.backgroundColor = xmlhttp.responseText;console.log(xmlhttp.responseText);}},xmlhttp.open("GET", string, true);xmlhttp.send(); }</script>
</head><body style="background-color:black">
<font size="12" color="yellow">
<b>
<div class="text" style=" text-align:center;"><big>Web 点灯</big></div>
</b>
</font>
<br> </br>     
<div align="center" id="txtState"style="margin:auto;width:160px;height:160px;border-radius:50%;background:white;"></div>
<br> </br>
<div style=" text-align:center;">
<input type="button" value="打开" style="width:160px;height:80px;background:green;" onclick="ledSwitch('on')" />
<input type="button" value="关闭" style="width:160px;height:80px;background:red;" onclick="ledSwitch('off')" />
</div>
</body>
</html>

 代码解释:

        (1)复制到.html中

        (2)打开EasyWebServer,设置主目录为桌面,端口号80

        (3)在浏览器中输入127.0.0.1/hello.html

四。最终实验:web点亮stm32的led灯

1.cubemx创建工程

 (0)串口,时钟,Freertos都配置完成

  (1)配置灯led6,初始化为高电平(不亮)

 (2)LWIP配置

使能DNS

 使能muticast

 使能IGMP 

2.步骤:

(1)修改端口号为80wAAACH5BAEKAAAALAAAAAABAAEAAAICRAEAOw==

(2)http_server.h

#ifndef _HTTP_SERVER_H
#define _HTTP_SERVER_Hvoid vHttpServerTask(void);#endif

(3)http_server.c

#include "socket_tcp_server.h"
#include "socket_wrap.h"
#include "ctype.h"
#include "http_server.h"
#include "string.h"static char ReadBuff[BUFF_SIZE];
char SendBuff[128];
char *HtmlPage = 
"<html>"
"<head>"
"<meta http-equiv=\"Content-Type\" content=\"text/html; charset=gb2312\" />"
"<title>web 点灯</title>"
"<script defer=\"defer\">"
"        function ledSwitch(string) {"
"            var xmlhttp;"
"            if (window.XMLHttpRequest) {"
"                xmlhttp = new XMLHttpRequest();"
"            } else {"
"                xmlhttp = new ActiveXObject(\"Microsoft.XMLHTTP\");"
"            }"
"            xmlhttp.onreadystatechange = function () {"
"                    if (xmlhttp.readyState == 4 && xmlhttp.status == 200) {"
"                        document.getElementById(\"txtState\").style.backgroundColor = xmlhttp.responseText;"
"						console.log(xmlhttp.responseText);"
"					}"
"                },"
"            xmlhttp.open(\"GET\", string, true);"
"            xmlhttp.send(); "
"        }"
"    </script>"
"</head>"
"<body style=\"background-color:black\">"
"<font size=\"12\" color=\"yellow\">"
"<b>"
"<div class=\"text\" style=\" text-align:center;\"><big>Web 点灯</big></div>"
"</b>"
"</font>"
"<br> </br>     "
"<div align=\"center\" id=\"txtState\"style=\"margin:auto;width:160px;height:160px;border-radius:50%;background:white;\"></div>"
"<br> </br>"
"<div style=\" text-align:center;\">"
"<input type=\"button\" value=\"打开\" style=\"width:160px;height:80px;background:green;\" onclick=\"ledSwitch(\'on\')\" />"
"<input type=\"button\" value=\"关闭\" style=\"width:160px;height:80px;background:red;\" onclick=\"ledSwitch(\'off\')\" />"
"</div>"
"</body>"
"</html>";void HttpParResponse(int cfd, char *Buff)
{//是否为请求主页if(strstr(Buff, "GET / HTTP/1.1") != NULL){//响应头sprintf(SendBuff, "HTTP/1.1 200 OK\r\n");Write(cfd, SendBuff, strlen(SendBuff));//响应首部sprintf(SendBuff, "Content-Type: text/html\r\n");Write(cfd, SendBuff, strlen(SendBuff));sprintf(SendBuff, "Connection: Keep-Alive\r\n");Write(cfd, SendBuff, strlen(SendBuff));sprintf(SendBuff, "Content-Length: %d\r\n", strlen(HtmlPage));Write(cfd, SendBuff, strlen(SendBuff));sprintf(SendBuff, "\r\n");Write(cfd, SendBuff, strlen(SendBuff));//响应主题Write(cfd, HtmlPage, strlen(HtmlPage));//是否为 打开led}else if(strstr(Buff, "GET /on HTTP/1.1") != NULL){Write(cfd, "red", strlen("red"));HAL_GPIO_WritePin(D6_GPIO_Port, D6_Pin, GPIO_PIN_RESET);//是否为 关闭led}else if(strstr(Buff, "GET /off HTTP/1.1") != NULL){Write(cfd, "white", strlen("white"));HAL_GPIO_WritePin(D6_GPIO_Port, D6_Pin, GPIO_PIN_SET);//请求资源无效, 就是404}else{printf("GET Method Error\r\n");close(cfd);}}/*** @brief  http 服务器任务* @param  None* @retval None*/
void vHttpServerTask(void){int 	 sfd, cfd, n;struct sockaddr_in server_addr, client_addr;socklen_t	client_addr_len;//创建socketsfd = Socket(AF_INET, SOCK_STREAM, 0);server_addr.sin_family 			= AF_INET;server_addr.sin_port   			= htons(SERVER_PORT);server_addr.sin_addr.s_addr = htonl(INADDR_ANY);//绑定socketBind(sfd, (struct sockaddr *)&server_addr, sizeof(server_addr));//监听socketListen(sfd, 5);//等待客户端连接client_addr_len = sizeof(client_addr);
again:cfd = Accept(sfd, (struct sockaddr *)&client_addr, &client_addr_len);printf("client is connect cfd = %d\r\n",cfd);while(1){//等待客户端发送数据n = Read(cfd, ReadBuff, BUFF_SIZE);if(n <= 0){goto again;}//解析响应http协议HttpParResponse(cfd, ReadBuff);//http响应后要关闭fdclose(cfd);goto again;}
}

4.结果

stm32为服务器,所以输入stm32的IP地址192.168.1.10,stm32的灯会被按钮控制。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/114798.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

微服务架构七种模式

微服务架构七种模式 目录概述需求&#xff1a; 设计思路实现思路分析 参考资料和推荐阅读 Survive by day and develop by night. talk for import biz , show your perfect code,full busy&#xff0c;skip hardness,make a better result,wait for change,challenge Survive.…

1773_把vim的tab键设置为4个空格显示

全部学习汇总&#xff1a; GitHub - GreyZhang/editors_skills: Summary for some common editor skills I used. 有时候自己觉得自己很奇怪&#xff0c;看着Linux的命令窗口就觉得很顺眼。那些花花绿绿的字符以及繁多的方便命令工具&#xff0c;确实是比Windows强不少。不过&a…

大数据时代下的精准营销

在大数据时代&#xff0c;人们的信息越来越透明&#xff0c;留在网络上的各种数据也是企业进行营销的一个重要的生产要素。一直以来&#xff0c;营销的科学性正是因为运用了自然科学中一级互联网中的数据收集手段&#xff0c;严谨的记录、搜集和分析消费者的各项数据和日常生活…

Openlayer系列:利用GeoServer和Openlayer地图显示区域掩模

前言 利用GeoServer和Openlayer地图显示区域掩模 利用GeoServer进行图层发布 Openlayer地图显示区域掩模 对界面地图进行切换&#xff0c;卫星图利用GeoServer&#xff0c;水系等根据geojson文件生成图层&#xff0c;效果如下 卫星图部分代码如下&#xff1a; // 创建卫星图…

在CentOS7中,安装并配置Redis【个人笔记】

一、拓展——Ubuntu上安装Redis 输入命令su --->切换到root用户【如果已经是&#xff0c;则不需要进行该操作】apt search redis --->使用apt命令来搜索redis相关的软件包【查询后&#xff0c;检查redis版本是否是你需要的&#xff0c;如果不是则需要看看其他资料~】ap…

蓝牙运动耳机哪个牌子好、好用的运动蓝牙耳机推荐

作为一个热爱运动的人&#xff0c;我对耳机非常关注。我相信许多喜欢运动的人在锻炼时都会佩戴耳机&#xff0c;这样可以为运动增添一份乐趣&#xff0c;享受自己喜爱的音乐或聆听有趣的小说&#xff0c;激发内心的动力。但很多人都不知道要怎么选一款优质的运动耳机&#xff0…

安捷伦Agilent E8362C网络分析仪

产品概述 Agilent E8362C网络分析仪提供通用网络分析&#xff0c;带有可选软件和/或硬件&#xff0c;可根据您的应用进行定制&#xff0c;如多端口、脉冲射频等。 Agilent E8362C网络分析仪的显示窗口数量不限&#xff0c;可以调整大小和重新排列&#xff0c;每个窗口最多有24…

python-数据分析-numpy、pandas、matplotlib的常用方法

一、numpy import numpy as np1.numpy 数组 和 list 的区别 输出方式不同 里面包含的元素类型 2.构造并访问二维数组 使用 索引/切片 访问ndarray元素 切片 左闭右开 np.array(list) 3.快捷构造高维数组 np.arange() np.random.randn() - - - 服从标准正态分布- - - …

【高阶数据结构】map和set的介绍和使用 {关联式容器;键值对;map和set;multimap和multiset;OJ练习}

map和set的介绍和使用 一、关联式容器 关联式容器和序列式容器是C STL中的两种不同类型的容器。 关联式容器是基于键值对的容器&#xff0c;其中每个元素都有一个唯一的键值&#xff0c;可以通过键值来访问元素。关联式容器包括set、multiset、map和multimap。 序列式容器是…

常静相伴:深度解析C++中的const与static关键字

个人主页&#xff1a;北海 &#x1f390;CSDN新晋作者 &#x1f389;欢迎 &#x1f44d;点赞✍评论⭐收藏✨收录专栏&#xff1a;C/C&#x1f91d;希望作者的文章能对你有所帮助&#xff0c;有不足的地方请在评论区留言指正&#xff0c;大家一起学习交流&#xff01;&#x1f9…

玩转 PI 系列-看起来像服务器的 ARM 开发板矩阵-Firefly Cluster Server

前言 基于我个人的工作内容和兴趣&#xff0c;想要在家里搞一套服务器集群&#xff0c;用于容器/K8s 等方案的测试验证。 考虑过使用二手服务器&#xff0c;比如 Dell R730, 还搞了一套配置清单&#xff0c;如下&#xff1a; Dell R7303.5 尺寸规格硬盘CPU: 2686v4*2 内存&a…

DBO优化SVM的电力负荷预测,附MATLAB代码

今天为大家带来一期基于DBO-SVM的电力负荷预测。 原理详解 文章对支持向量机(SVM)的两个参数进行优化&#xff0c;分别是&#xff1a;惩罚系数c和 gamma。 其中&#xff0c;惩罚系数c表示对误差的宽容度。c越高&#xff0c;说明越不能容忍出现误差,容易过拟合。c越小&#xff0…

链表OJ练习(1)

一、移除链表元素 本题为力扣原题203 题目介绍&#xff1a; 给你一个链表的头节点 head 和一个整数 val &#xff0c;请你删除链表中所有满足 Node.val val 的节点&#xff0c;并返回 新的头节点 。 列表中的节点数目范围在 0~10000内 1<Node.val<50 0<val<50 …

基于VUE3+Layui从头搭建通用后台管理系统(前端篇)十一:通用表单组件封装实现

一、本章内容 本章实现通用表单组件,根据实体配置识别实体属性,并自动生成编辑组件,实现对应数据填充、校验及保存等逻辑。 1. 详细课程地址: 待发布 2. 源码下载地址: 待发布 二、界面预览 三、开发视频 3.1 B站视频地址:

OpenCV

文章目录 OpenCV学习报告读取图片和网络摄像头1.1 图片读取1.2 视频读取1.1.1 读取视频文件1.1.2读取网络摄像头 OpenCV基础功能调整、裁剪图像3.1 调整图像大小3.2 裁剪图像 图像上绘制形状和文本4.1 图像上绘制形状4.2图像上写文字 透视变换图像拼接颜色检测轮廓检测人脸检测…

【Nacos】使用Nacos进行服务发现、配置管理

Nacos Nacos是 Dynamic Naming and Configuration Service 的首字母简称&#xff0c;一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。 版本说明&#xff1a;版本说明 alibaba/spring-cloud-alibaba Wiki GitHub <properties><java.version>…

传统分拣弊端明显,AI机器视觉赋能物流行业包裹分类产线数智化升级

随着电子商务的快速发展&#xff0c;物流行业的包裹数量持续增长&#xff0c;给物流企业带来了巨大的运营压力。目前&#xff0c;国内大型物流运转中心已开始采用机器视觉自动化设备&#xff0c;但多数快递公司处于半自动化状态&#xff0c;中小型物流分拣中心目前仍靠人工录入…

AI机器视觉赋能电池缺陷检测,深眸科技助力新能源行业规模化发展

新产业周期下&#xff0c;新能源行业风口已至&#xff0c;现代社会对于新能源电池产品需求量加大&#xff0c;对产品的质量安全也更加重视。当前&#xff0c;传统的检测方法已经不能满足新能源电池行业的发展&#xff0c;越来越多的厂商开始应用创新机器视觉技术与产品于生产环…

Python 实战之ChatGPT + Python 实现全自动数据处理/可视化详解

本文目录 一、引言 二、成果演示——口述式数据可视化 三、远原理述 四、实现过程 &#xff08;一&#xff09;环境配置 &#xff08;二&#xff09;申请OpenAI账号 &#xff08;一&#xff09;调用ChatGPT API &#xff08;二&#xff09;设计AI身份&#xff0c;全自动处理数据…