【计算机网络】HTTP响应报文&Cookie原理

目录

HTTP响应报文格式

一. 状态行

状态码与状态码描述

二. 响应头

一. 前因

二. Cookie的状态管理

结束语


HTTP响应报文格式

【计算机网络】HTTP响应报文&Cookie原理_第1张图片

HTTP响应报文分为四部分

  • 状态行:包含三部分:协议版本,状态码,状态码描述
  • 响应头:响应体的一些属性信息
  • 空行:由回车符和换行符组成---\r\n
  • 响应体(有效载荷):响应给请求方的内容,如网页,视频,音频等

PS:我们访问腾讯网其中的每一个可以点击的链接,都会发起一次HTTP请求

一. 状态行

状态行包含三部分,彼此之间使用空格分隔

协议版本是服务器使用的HTTP的协议版本。方便和客户端的HTTP协议进行版本兼容

状态码与状态码描述

类别 原因短语
1XX Informational(信息性状态码) 接收的请求正在处理
2XX Success(成功状态码) 请求正常处理完毕
3XX Redirection(重定向状态码) 需要进行附加操作以完成请求
4XX Client Error(客户端错误状态码) 服务器无法处理请求
5XX Server Error(服务器) 服务器处理请求出错

  • 2XX状态码
  • 表示服务器已成功收到请求并进行处理
状态码 状态码英文名称 中文描述
200 OK 请求成功。一般与GET与POST请求
201 Created 已创建。成功请求并创建了新的资源。通常用于POST或PUT请求

  • 3XX状态码
  • 表示服务器要求客户端重定向,需要客户端进一步的操作已完成资源的请求
状态码 状态码英文名称 中文描述
301 Moved Permanently 永久移动。请求的资源已经被永久的移动到新的URL,返回信息会包括新的URL,浏览器会自动定向到新URL。今后任何新的请求都应使用新的URL替代
302 Found 临时移动。与301类似。但资源只是被临时移动。客户端应继续原有URL访问
304 Not Modified 未修改。所请求的资源未修改,服务器返回状态码时,不会返回任何资源(响应信息中不包含响应体)。客户端通常会缓存访问过的资源
  • 4XX状态码
  • 表示客户端的请求有非法内容
状态码 状态码英文名称 中文描述
401 Unauthorized 当前请求需要用户验证
403 Forbidden 服务器已经理解请求,但拒绝执行
404 Not Found 请求失败。服务器无法根据客户端的请求找到资源(网页)
408 Request Timeout 请求超时。服务器等待客户端发送的请求时间过长,超时
400 Bad Request

1. 语义有误,当前请求无法被服务器理解。除非进行修改,否则客户端不应该重复提交这个请求

2. 请求参数有误

  • 5XX状态码
  • 表示服务器未能正常处理客户端的请求而出现意外错误
状态码 状态码英文名称 中文描述
500 Internal Server Error 服务器遇到了不知道如何处理的情况。
501 Not Implemented 此请求方法不被服务器支持且无法被处理。只有GET和HEAD是要求服务器支持的,它们必定不会返回此错误代码。
503 Service Unavailable 服务器没有准备好处理请求。由于超载或系统维护,服务器暂时的无法处理客户端的请求。

常见的状态码比如200(OK),404(Not Found),403(Forbidden),302(Redirect 重定向),504(Bad Gatewat)

完整的响应状态码及描述可以参看MDN官方文档:HTTP 响应状态码 - HTTP | MDN

补充:重定向

访问网页的不仅有用户,还有爬虫。永久重定向的应用之一就是服务搜索引擎。当搜索引擎爬虫到一个永久重定向的网页,就会将新的URL替代原先的URL,不需要每次都重定向

二. 响应头

响应头都是以KV关系保存的信息,包含附加动作,响应体(有效载荷)的属性等

常见的响应头:

Content-Length:响应体(有效载荷)的长度

Content-Type:响应体(有效载荷)的类型(网页,图片,音频等)

Content-Language:响应体(有效载荷)的语言环境

Content-Encoding:响应体(有效载荷)的压缩格式

Location:重定向的位置,新的URL地址、配合301,304使用

Connection:如Keep-Alive,表示保持tcp连接不关闭

referer:当前页面是从哪个页面跳转过来的

Set-Cookie:返回sid,供客户端下次访问使用

一. 前因

HTTP是无状态协议,它不对之前发生的请求和响应的状态进行管理。也就是说,无法根据之前的状态进行本次的请求处理

上述现象导致,比如访问B站,VIP视频需要登录验证,但每换一个VIP视频都需要登录验证一次,因为无法根据之前的登录状态进行本次请求处理。这显示是不能接受的

二. Cookie的状态管理

【计算机网络】HTTP响应报文&Cookie原理_第2张图片

【计算机网络】HTTP响应报文&Cookie原理_第3张图片

图片来自网络

Cookie是服务端生成的,保存在客户端。Cookie有两种保存方法:

  1. 内存级:保存浏览器运行的内存中
  2. 文件级:(1). 持久,需要手动清理 (2). 非持久,有过期时间

【计算机网络】HTTP响应报文&Cookie原理_第4张图片

客户端(浏览器)将Cookie保存,并在后续的访问中,将Cookie携带在HTTP请求报文中

结束语

本篇博客到此结束,感谢看到此处。
欢迎大家纠错和补充
如果觉得本篇文章对你有所帮助的话,不妨点个赞支持一下博主,拜托啦,这对我真的很重要。

你可能感兴趣的:(计算机网络学习之路,计算机网络,学习,网络,http,网络协议)