hello,大家好,今天为大家带来http协议的相关知识
1.HTTP协议
🐷1.应用层协议
🐷2.HTTP协议的工作过程
2.HTTP协议格式
🐷1.认识抓包工具Fidder
🐷2.学会使用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协议的工作过程
我们在浏览器上输入https://www.baidu.com/,与之对应的弹出一个百度的搜索页面
这里的绿色框里的输入的一串URL就是请求,而百度搜索页面就是响应
这里的客户端就是浏览器页面,服务器就是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:片段标识符
这个就是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~~~