HTTP协议Header选项解读

简介: header的语法格式是“key”:“value”的形式,一行一个header,每一个header都有其对应的特殊作用。

1

HTTP Header介绍


相信大家对header并不陌生,在做接口测试的时候经常会用到,那么header到底是什么呢?

可以将header看成是一种规范,约定好客户端和服务器能做的一些事情等,http请求和响应中都会包含header,通常我们可以检查为 请求头和响应头。

header的语法格式是“key”:“value”的形式,一行一个header,每一个header都有其对应的特殊作用。

使用Fiddler抓包工具可以看到http请求和响应的header信息:


微信图片_20220113225911.png


2

Header常见选项解读


Cache

Cache指的是缓存相关的Header,在HTTP请求中,不管是请求头还是响应头,都有可能会出现Cache相关的选项,当http需要请求的资源在本地有缓存的副本的话,就可以直接从本地存储设备中提取,不用再次从服务器下载,当http请求接口的数据命中后端缓存的时候,后端接口就可以从缓存中直接返回相应的数据,不用再查库。请求信息是否有采用缓存,是可以从fiddler抓包的信息中观察到的:


微信图片_20220113225915.png


缓存的优点:

1、减少了冗余的数据传输,节省了传输时间

2、减少了服务器的负担,大大提高了网站的性能

3、加快了客户端加载网页的速度

这里顺带附上一篇之前写的跟缓存相关的文章:接口加了缓存之后如何验证缓存是否有效


Cookies

一般包含了用户登录后的一些校验信息,用于后台校验用户身份


微信图片_20220113225918.png



Accept

Accept表示客户端可以接受的返回结果类型。

例如,Accept:text/html代表客户端可以接受服务器返回html格式的内容。


Accept-Encoding

告诉服务器,客户端支持xxx压缩格式。Accept-Encoding: gzip, deflate


Accept-Language

浏览器用来声明自己接受的语言,比如Accept-Language: zh-CN,zh;q=0.9,en;q=0.8


User-Agent

User-Agent的作用是告诉服务器,客户端使用的操作系统及版本,浏览器类型及版本等信息。

通过Fiddler工具,可以修改User-Agent,伪装成其他客户端发送请求:

Fiddler->菜单栏Rules->User-Agents


微信图片_20220113225921.png


User-Agent这个参数在爬虫的时候可能会用的比较多,伪造不同的客户端去发送请求,降低被服务的屏蔽的概率。

Referer

Referer主要是用来让服务端判断来源页面,即用户是从哪个入口链接过来的。一般的网站都会在后台去分析和统计流量的入口,以便及时调整推广的策略之类的。

比如,从百度上搜索某个关键词,跳转到csdn网站的时候,都是带了referer的信息的:


微信图片_20220113225924.png


微信图片_20220113225927.png


Connection

从HTTP/1.1起,系统默认都开启了Connection:Keep-Alice,保持连接特性。

HTTP请求发送之前,需要先建立TCP连接,只有TCP连接建立,才可以发送HTTP请求。使用长连接,HTTP发送下一个请求的时候可以直接发送,不需要再次建立TCP连接。Keep-Alice不会永久保持连接,它有一个保持时间,一般可以在后台进行配置。


相关文章
|
1月前
|
缓存 应用服务中间件 网络安全
Nginx中配置HTTP2协议的方法
Nginx中配置HTTP2协议的方法
94 7
|
5天前
|
域名解析 缓存 网络协议
Web基础与HTTP协议
通过掌握这些基础知识和技术,开发者可以更加高效地构建和优化Web应用,提供更好的用户体验和系统性能。
42 15
|
3天前
|
缓存 网络协议 算法
从零开始掌握HTTP协议
本文介绍HTTP协议的演变,从HTTP1.0到HTTP2.0。HTTP1.0为无状态连接,每次请求独立;HTTP1.1引入持久连接、管道化请求和更多状态码;HTTP2.0采用二进制分帧、多路复用、头部压缩及服务器主动推送,大幅提升性能与用户体验。了解这些区别有助于开发者优化应用和服务。
|
3天前
|
网络协议 安全 网络安全
探索网络模型与协议:从OSI到HTTPs的原理解析
OSI七层网络模型和TCP/IP四层模型是理解和设计计算机网络的框架。OSI模型包括物理层、数据链路层、网络层、传输层、会话层、表示层和应用层,而TCP/IP模型则简化为链路层、网络层、传输层和 HTTPS协议基于HTTP并通过TLS/SSL加密数据,确保安全传输。其连接过程涉及TCP三次握手、SSL证书验证、对称密钥交换等步骤,以保障通信的安全性和完整性。数字信封技术使用非对称加密和数字证书确保数据的机密性和身份认证。 浏览器通过Https访问网站的过程包括输入网址、DNS解析、建立TCP连接、发送HTTPS请求、接收响应、验证证书和解析网页内容等步骤,确保用户与服务器之间的安全通信。
25 1
|
1月前
|
开发者
HTTP 协议请求方法的发展历程
【10月更文挑战第21天】
|
1月前
|
Dubbo 安全 应用服务中间件
Apache Dubbo 正式发布 HTTP/3 版本 RPC 协议,弱网效率提升 6 倍
在 Apache Dubbo 3.3.0 版本之后,官方推出了全新升级的 Triple X 协议,全面支持 HTTP/1、HTTP/2 和 HTTP/3 协议。本文将围绕 Triple 协议对 HTTP/3 的支持进行详细阐述,包括其设计目标、实际应用案例、性能测试结果以及源码架构分析等内容。
|
29天前
|
安全 搜索推荐 网络安全
HTTPS协议是**一种通过计算机网络进行安全通信的传输协议
HTTPS协议是**一种通过计算机网络进行安全通信的传输协议
55 11
|
19小时前
|
前端开发 网络协议 安全
【网络原理】——HTTP协议、fiddler抓包
HTTP超文本传输,HTML,fiddler抓包,URL,urlencode,HTTP首行方法,GET方法,POST方法
|
29天前
|
缓存 安全 网络协议
HTTPS协议的历史发展
HTTPS协议的历史发展
42 8
|
1月前
|
安全 应用服务中间件 Linux
判断一个网站是否使用HTTPS协议
判断一个网站是否使用HTTPS协议
47 4

热门文章

最新文章