HTTP协议

  1. HTTP协议的概述:超文本传输协议,作用就是规定浏览器与服务器之间发送接收数据的规范

HTTP协议特点:

  1. 基于TCP协议(传输控制协议):面向链接,安全
  2. 基于请求-响应模型:一次请求的对应一次响应
  3. HTTP协议是无状态协议:对于失误处理没有记忆能力。没次请求响应都是独立的

缺点:多次请求不能共享数据

优点:速度快

HTTP的请求、响应

HTTP请求数据格式

请求数据分为三个部分:

  1. 请求行:请求数据的第一行。其中GET表示请求方式,/

表示请求资源路径,HTTP/1.1表示协议版本

  1. 请求头:都是KEY:VALUE的格式组成的一些数据,让服务器更好的分辨本次浏览器的相关信息,更好的响应!
  2. 请求体:POST请求的最后部一部分,存放请求参数(本次请求中携带的参数(只有提交方式POST才有请求体))

常见的HTTP请求头

  1. Host:表示请求的主机名
  2. User-Agent:浏览器的标识类类似Mozilla/5.0(Windows NT..)like Gecko
  3. Accept-Language:表示浏览器偏好的语言,服务器可以据此返回不同的语言的网页;
  4. Accept-Encoding:表示浏览器可以支持的压缩类型,例如gzip,deflate等。

GET请求和POST的区别:

  1. GET请求:请求参数在请求行中,没有请求体
  2. POST请求:请求参数大小有限制,POST没有

HTTP相应数据格式

响应数据分为三个部分:

  1. 响应行:响应数据的第一行。其中HTTP/1.1表示协议版本,200表示响应状态码,ok表示状态码描述
  2. 响应头:第二行开始格式为key:value形式
  3. 响应体:最后一部分存放响应程序

状态码大分类

  1. 1xx   | **响应中**——临时状态码,表示请求已经接受,告诉客户端应该继续请求或者如果它已经完成则忽略它
  2. 2xx  | **成功**——表示请求已经被成功接收,处理已完成
  1. 3xx  | **重定向**——重定向到其它地方:它让客户端再发起一个请求以完成整个处理。
  2. 4xx  | **客户端错误**——处理发生错误,责任在客户端,如:客户端的请求一个不存在的资源,客户端未被授权,禁止访问等 |
  3. 5xx  | **服务器端错误**——处理发生错误,责任在服务端,如:服务端抛出异常,路由出错,HTTP版本不支持等.

 状态码大全:状态 | Status - HTTP 中文开发手册 - 开发者手册 - 腾讯云开发者社区-腾讯云

常见的响应状态码

200

OK

客户端请求成功,即处理成功,这是我们最想看到的状态码

302

Found

指示所请求的资源已移动到由Location响应头给定的 URL,浏览器会自动重新访问到这个页面

304

Not Modified

告诉客户端,你请求的资源至上次取得后,服务端并未更改,你直接用你本地缓存吧。隐式重定向

400

Bad Request

客户端请求有语法错误,不能被服务器所理解

403

Forbidden

服务器收到请求,但是拒绝提供服务,比如:没有权限访问相关资源

404

Not Found

请求资源不存在,一般是URL输入有误,或者网站资源被删除了

428

Precondition Required

服务器要求有条件的请求,告诉客户端要想访问该资源,必须携带特定的请求头

429

Too Many Requests

太多请求,可以限制客户端请求某个资源的数量,配合 Retry-After(多长时间后可以请求)响应头一起使用

431

Request Header Fields Too Large

请求头太大,服务器不愿意处理请求,因为它的头部字段太大。请求可以在减少请求头域的大小后重新提交。

405

Method Not Allowed

请求方式有误,比如应该用GET请求方式的资源,用了POST

500

Internal Server Error

服务器发生不可预期的错误。服务器出异常了,赶紧看日志去吧

503

Service Unavailable

服务器尚未准备好处理请求,服务器刚刚启动,还未初始化好

511

Network Authentication Required

客户端需要进行身份验证才能获得网络访问权限

常见的HTTP响应头

Content-Type:表示该相应内容的类型,例如text/html,image/jpeg;

Content-Length:表示该相应内容的长度(字节数);

Content-Encoding:表示压缩算法,例如gzip;

Content-Control:只是客户段应如何缓存,例如max-age = 300

表示最多可以缓存300秒

浏览器开发工具使用方式 推荐(Edge/Chrome/Firefox)

强烈推荐:Firefox  能显示最原始的请求头

  1. 在浏览器种打开开发这工具 F12

uploading.4e448015.gif

正在上传…重新上传取消

  1. 元素:当前页面的组成部分
  2. 控制台:类似Java的控制台可以输入一些命令
  3. 网络:记录当前页面发送出去的所有请求以及对应的响应信息

uploading.4e448015.gif

正在上传…重新上传取消

查看请求相关内容

uploading.4e448015.gif

正在上传…重新上传取消

响应头

uploading.4e448015.gif

正在上传…重新上传取消

响应体

uploading.4e448015.gif

正在上传…重新上传取消

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值