Web开发核心

embedded/2024/9/22 19:30:10/

文章目录

  • 1.http协议简介
  • 2.http协议特性
  • 3.http请求和响应协议
  • 4.最简单的Web程序
  • 5.基于flask搭建web⽹站
  • 6.浏览器开发者⼯具(重点)

1.http协议简介

HTTP协议是Hyper Text Transfer Protocol(超文本传输协议)的缩写,是用于
万维网(WWW:Norld Wide Web)服务器与本地浏览器之间传输超文本的
传送协议。HTTP是一个属于应用层的面向对象的协议,由于其简捷、快速
的方式,适用于分布式超媒体信息系统。它于1990年提出,经过几年的使
用与发展,得到不断地完善和扩展。HTTP协议工作于客户端服务端架构为
上。浏览器作为HTTP客户端通过URL向HTTP服务端即WEB服务器发送所有
请求。Web服务器根据接收到的请求后,向客户端发送响应信息。
![[Pasted image 20240525200441.png]]

2.http协议特性

  1. 基于TCP/IP协议
    http协议是基于TCP/IP协议之上的应用层协议。
  2. 基于请求一响应模式
    HTTP协议规定,请求从客户端发出,最后服务器端响应该请求并返回。换句话说,肯定
    是先从客户端开始建立通信的,服务器端在没有接收到请求之前不会发送响应
  3. 无状态保存
    HTTP是一种不保存状态,即无状态(stateless)协议。HTTP协议自身不对请求和响
    应之间的通信状态进行保存。也就是说在“TTP这个级谜别,协议对于发送过的请求或响
    应都不做持久化处理。
    使用HTTP协议,每当有新的请求发送时,就会有对应的新响应产生。协议本身并不保
    留之前一切的请求或响应报文的信息。这是为了更快地处理大量事务,确保协议的可
    伸缩性,而特意把HTTP协议设计成如此简单的。
  4. 短连接和长连接
    HTTP1.O默认使用的是短连接。浏览器和服务器每进行一次HTTP操作,就建立一次
    连接,任务结束就中断连接。
    HTTP/1.1起,默认使用长连接。要使用长连接,客户端和服务器的HTTP首部的
    Connection都要没置为keep-a]iye,才能支特长连接HTTP长连接,指的是复用TCP连接。多个HTTP请求可以复用同一个TCP连接,这就节省了TCP连接建立和断开的消耗。

3.http请求和响应协议

![[Pasted image 20240525200948.png]]

htp协议包含由浏览器发送数据到服务器需要遵循的请求协议与服务器发送数据到浏览器需要遵循的请求协议。用于HTTP协议交互的信被为HTTP报文。请求端(客户端)的HTTP报文做请求报文,响应端(服务器端)的做响应报文。HTTP报文本身是由多行数据构成的字文本。
![[Pasted image 20240525201022.png]]

一个完整的URL包括:协议、ip、端口、路径、参数
例如:https:/www.baidu.com/s?wd=yuan
其中https是协议,www,baidu.com是IP,端口默认80,/s是路径,参数是wd=yuan请求方式:get与post请求GET提交的数据会放在URL之后,以?分割URL和传输数据,参数之
间以&相连,如EditBook?name=test1&id=123456.P0ST方法是把提交
的数据放在HTTP包的请求体中
GET提交的数据大小有限制(因为浏览器对URL的长度有限制),而POST方法提交的数据没有限制
响应状态码:状态码的职是当客户端向服务器端发送请求时,返回的请求结果。借助状态码,用户可以知道服务器端是正常理了请求,还是出现了。状态码如2000K,以3位数字和原因组成。

4.最简单的Web程序

import socket  sock = socket.socket()  
sock.bind(("127.0.0.1", 7777))  
sock.listen(3)  print("服务器已启动..")  
while True:  conn, addr = sock.accept()  data = conn.recv(1024)  print("收到请求:", data.decode())  response = """HTTP/1.1 200 OK\r\nContent-Type: text/html\r\n\r\n  <h1>Hello, World!</h1>    <img src='https://img0.baidu.com/it/u=4011424408,4733765&fm=253&fmt=auto&app=138&f=JPEG?W=500&h=750'>"""  conn.sendall(response.encode())  conn.close()

5.基于flask搭建web⽹站

from flask import Flask, render_template  
import datetime  app = Flask(__name__, template_folder="templates")  @app.route("/index")  
def index():  return render_template("index.html")  @app.route("/timer")  
def timer():  now = datetime.datetime.now().strftime("%Y-%m-%d %X")  return render_template("timer.html", now=now)  app.run()

6.浏览器开发者⼯具(重点)

(1)Elements
(2)Network
(3)Application


http://www.ppmy.cn/embedded/42756.html

相关文章

嵌入式学习——3——TCP并发(未完成)

1、多进程实现TCP并发 //定义信号处理函数 void handler(int signo) {if(signo SIGCHLD){// 回收所有的僵尸进程while(waitpid(-1, NULL, WNOHANG) ! 0); } }int main(){//将SIGCHLD信号绑定到信号处理函数中signal(SIGCHLD, handler);sfd socket(); //创建用于…

B站滑块登录之极验点选

滑块登录这些东西都不是很难&#xff0c;我个人的去处理的话一般会考虑三种方案&#xff0c;一个是自动化selenium 二是各类打码平台 三是ocr识别&#xff0c;本文是selenium接打码平台&#xff0c;也是个比较常规的操作。 先常规步骤跟着来吧&#xff0c;做登录的话把基本的模…

算法随想录第十三天打卡|239. 滑动窗口最大值,347.前 K 个高频元素

239. 滑动窗口最大值 &#xff08;一刷至少需要理解思路&#xff09; 之前讲的都是栈的应用&#xff0c;这次该是队列的应用了。 本题算比较有难度的&#xff0c;需要自己去构造单调队列&#xff0c;建议先看视频来理解。 题目链接/文章讲解/视频讲解&#xff1a;代码随想录 c…

MySQL8.0新特性CTE表达式递归实现累加运算 1+2+…+n 等于多少?

上一篇内容&#xff0c;通过MySQL存储过程实现累加运算 12…n 等于多少的需求&#xff0c;使用当前主流版本MySQL5.7.x 和MySQL8.0.x&#xff0c;以及最新的MySQL8.4 LST版本。 WITH AS子句在MySQL 8.0.x及更高版本中得到支持&#xff0c;而在MySQL 5.7及以下版本中则不支持。…

设计模式之六大设计原则

文章目录 高内聚低耦合设计原则开闭原则单一职责原则里氏代换原则依赖倒置原则迪米特原则接口隔离原则 高内聚低耦合 提高代码的可读性、可维护性和可扩展性&#xff0c;降低开发和维护的成本&#xff0c;并减少系统的风险 内聚&#xff1a; 表示内部间聚集、关联的程度 耦合…

东方通TongWeb结合Spring-Boot使用

一、概述 信创需要; 原状:原来的服务使用springboot框架,自带的web容器是tomcat,打成jar包启动; 需求:使用东方通tongweb来替换tomcat容器; 二、替换步骤 2.1 准备 获取到TongWeb7.0.E.6_P7嵌入版 这个文件,文件内容有相关对应的依赖包,可以根据需要来安装到本地…

Mysql自增id、uuid、雪花算法id的比较

MySQL自增id: 优点&#xff1a; 1.简单易用 ​ MySQL自增id 由数据库自动生成。 2.效率高 自增id是按顺序递增的&#xff0c;可以提高插入和查询的效率。 3.索引效率高 自增id可以作为主键或索引列&#xff0c;提高查询效率。 缺点&#xff1a; 1.不适用于分布式系统 在分布式…

vue2vue3为什么el-table树状表格失效?

上图所示&#xff0c;后端返回字段中有hasChildren字段。 解决树状表格失效方案&#xff1a; 从后端拿到数据后&#xff0c;递归去掉该字段&#xff0c;然后就能正常显示。&#xff08;复制下方代码&#xff0c;直接用&#xff09; 亲测有效&#xff0c;vue2、vue3通用 /**…