认识HTTP协议---1

简介: 认识HTTP协议---1

hello,大家好,今天为大家带来http协议的相关知识

1.HTTP协议

🐷1.应用层协议

🐷2.HTTP协议的工作过程

2.HTTP协议格式

🐷1.认识抓包工具Fidder

🐷2.学会使用fidder

fidder

🐷3.协议格式总结

3.HTTP请求

🐷1.认识URL

🐷2.认识请求

4.HTTP响应

🐷1.认识响应

5.总结get和post

下面我们就进入正题吧

1.HTTP协议

🐷1.应用层协议

既然要讲http协议,就要提到TCP/IP五层模型

我们可以清楚的看到http协议属于应用层的协议,应用层协议也就是可以理解成和用户进行交互的协议,就是不关心通信过程,只关注应用交互


🐷2.http协议的工作过程


http协议全称HyperText Transfer Protocol,是一个超文本协议, 往往是基于传输层的 TCP 协议实现的.


HTTP是一个"一问一答"的协议,就是一个请求返回一个响应,我们也谈到过多请求多响应,一个请求,多个响应的情况,这里不在赘述

我们来画个图理解http协议的工作过程


184d7b7bc8b440d7ab7ef63e55dc2f70.png

我们在浏览器上输入https://www.baidu.com/,与之对应的弹出一个百度的搜索页面

这里的绿色框里的输入的一串URL就是请求,而百度搜索页面就是响应


6a1e4224b9e8404588c48a7a62c3b930.png

这里的客户端就是浏览器页面,服务器就是HTTP服务器

客户端向服务器输入一个网址请求,服务器解析解析请求,构造响应,并返回给客户端


http是应用层协议,请求发出要向下一层层封装,接收方收到的时候也是从下到上层层分用,最后完成传输


2.HTTP协议格式


1.认识抓包工具Fidder

我们学习http协议就是要认识http的报文协议格式,那么就要借助抓包工具才能看到,现在认识一下抓包工具Fidder

它长这样,这个词可能有点抽象,就是可以把它当做中介,


比如我要买房子,我不和卖方的人直接交流,我和中介说,中介和卖房子的交流,那么中介就知道我和卖房子之间的所有信息,这是为了方便理解说的,实际上应该叫做代理

,画个图来理解

Fidder相当于一个代理,客户端要向服务器发发送请求,就交给fidder转发,服务器返回响应也交给fiddler转发


🐷2.学会使用fidder

我们现在来抓个包看看

33行处就是fiddler抓到的包


🐷3.协议格式总结

点开这个被抓的包

这个绿色框里面的就是http请求,红色框里面的就是http响应

我们点击raw,点击view in notepad,具体来认识协议格式

这一段就是http请求的报文格式


这是http响应的报文格式

3.HTTP请求

🐷1.认识URL

GET:代表http方法,这里表示调用的是http方法是get方法

这个就是URL,是唯一资源定位符,描述了网络上的一个资源

再来看一个URL


http://user:pass@www.example.jp:80/dir/index.html?uid=1#ch1


http:协议名


user:pass:登录信息(认证)


@www.example.jp:域名,(服务器地址)


80:服务器端口号(http默认是8080,HTTPS默认是443)


dir/index.html:带层次的文件路径(表示要访问的服务器资源是啥)


uid=1:查询字符串

(query string 中的内容是键值对结构. 其中的 key 和 value 的取值和个数, 完全都是程序猿自己约定)

规则:使用&分割键值对,使用=分割键和值)


#ch1:片段标识符

156125cbc85840b9994d403d829283f6.png

这个就是http服务器的版本号,一般都是HTTP/1.1

🐷2.认识请求

来看看http的方法都有哪些

GET请求

get请求,有四部分构成,首行,header,空行,body


对于get请求来说body一般没有

空行就相当于是 “报头的结束标记”, 或者是 “报头和正文之间的分隔符”.

HTTP 在传输层依赖 TCP 协议, TCP 是面向字节流的. 如果没有这个空行, 就会出现 “粘包问题”.

4.HTTP响应

来看响应

响应和请求一样都是文本文件,但是响应被压缩了,所以变成了二进制文件,我们依然使用view in notepad来看

Post请求

post请求一般是登录或者上传某个文件的时候才能看到

post请求一般没有URL,一般都有body


5.总结get和post


总体来说,get和post都是向服务器发送请求,没有什么本质区别,但是在使用习惯上有很大区别

1.get习惯上用来表示获取一个数据,post用来表示提交一个数据

2.get请求一般没有body,需要携带的数据放到URL里,post一般有body

3.get请求通常会设置为幂等的,post没有要求

4.get是可缓存的,(前提是幂等)post不能

5.get请求可以被浏览器收藏,post不能

6.有些资料上说 “POST 比 GET 请安全”. 这样的说法是不科学的. 是否安全取决于前端在传输密码等敏感信息时是否进行加密, 和 GET POST 无关.

7.关于传输数据量: 有的资料上说 “GET 传输的数据量小, POST 传输数据量大”. 这个也是不科学的, 标准没有规定 GET 的 URL 的长度, 也没有规定 POST 的 body 的长度. 传输数据量多少, 完全取决于不同浏览器和不同服务器之间的实现区别.具体可以查看RFC官方文档


https://www.rfc-editor.org/rfc/rfc2616


最后来解释一下什么叫幂等


就是说请求是一定的,响应也是一定的,比如牛吃的是草,挤出来就一定是牛奶,不能是别的,如果挤出来的是水,那就不符合幂等

太阳东升西落,如果不符合这个规定,那也不是幂等的!

今天的讲解就到这里,我们下期继续讲解http协议相关的知识,886~~~

相关文章
|
2月前
|
缓存 应用服务中间件 网络安全
Nginx中配置HTTP2协议的方法
Nginx中配置HTTP2协议的方法
169 7
|
1天前
|
缓存 网络协议 前端开发
Web 性能优化|了解 HTTP 协议后才能理解的预加载
本文旨在探讨和分享多种预加载技术及其在提升网站性能、优化用户体验方面的应用。
Web 性能优化|了解 HTTP 协议后才能理解的预加载
|
6天前
|
XML JSON 前端开发
HTTP协议,Content-Type格式介绍篇
通过理解和正确使用Content-Type头字段,可以确保数据在网络上传输时的正确性和高效性,提升网络应用的可靠性和用户体验
51 28
|
4天前
|
XML JSON 前端开发
HTTP协议,Content-Type格式介绍篇
通过理解和正确使用Content-Type头字段,可以确保数据在网络上传输时的正确性和高效性,提升网络应用的可靠性和用户体验。
92 25
|
7天前
|
XML JSON 前端开发
HTTP协议,Content-Type格式介绍篇
通过理解和正确使用Content-Type头字段,可以确保数据在网络上传输时的正确性和高效性,提升网络应用的可靠性和用户体验。
133 18
|
27天前
|
域名解析 缓存 网络协议
Web基础与HTTP协议
通过掌握这些基础知识和技术,开发者可以更加高效地构建和优化Web应用,提供更好的用户体验和系统性能。
72 15
|
23天前
|
前端开发 网络协议 安全
【网络原理】——HTTP协议、fiddler抓包
HTTP超文本传输,HTML,fiddler抓包,URL,urlencode,HTTP首行方法,GET方法,POST方法
|
25天前
|
缓存 网络协议 算法
从零开始掌握HTTP协议
本文介绍HTTP协议的演变,从HTTP1.0到HTTP2.0。HTTP1.0为无状态连接,每次请求独立;HTTP1.1引入持久连接、管道化请求和更多状态码;HTTP2.0采用二进制分帧、多路复用、头部压缩及服务器主动推送,大幅提升性能与用户体验。了解这些区别有助于开发者优化应用和服务。
|
25天前
|
网络协议 安全 网络安全
探索网络模型与协议:从OSI到HTTPs的原理解析
OSI七层网络模型和TCP/IP四层模型是理解和设计计算机网络的框架。OSI模型包括物理层、数据链路层、网络层、传输层、会话层、表示层和应用层,而TCP/IP模型则简化为链路层、网络层、传输层和 HTTPS协议基于HTTP并通过TLS/SSL加密数据,确保安全传输。其连接过程涉及TCP三次握手、SSL证书验证、对称密钥交换等步骤,以保障通信的安全性和完整性。数字信封技术使用非对称加密和数字证书确保数据的机密性和身份认证。 浏览器通过Https访问网站的过程包括输入网址、DNS解析、建立TCP连接、发送HTTPS请求、接收响应、验证证书和解析网页内容等步骤,确保用户与服务器之间的安全通信。
94 1
|
2月前
|
开发者
HTTP 协议请求方法的发展历程
【10月更文挑战第21天】
101 45