(1)Expires:HTTP/1.0 的时间戳标记
Expires: Wed, 21 Oct 2027 07:28:00 GMT
(2)cache-control:HTTP/1.1 的相对时间控制
cache-control: public, max-age=31536000 // 缓存1年
const express = require('express');
const app = express();
app.get('*', (req, res) => {
// 设置缓存10分钟(600秒),公共缓存
res.setHeader('cache-control', 'public, max-age=600');
res.end('资源内容');
});
app.listen(3031);
指令分类 | 常用值 | 作用描述 |
---|---|---|
可缓存性 | public | 资源可被任何设备缓存(包括代理服务器) |
private | 资源仅可被用户本地浏览器缓存,代理服务器不可缓存 | |
no-cache | 强制缓存前需先向服务器验证资源有效性(走协商缓存流程) | |
no-store | 禁止任何形式的缓存,每次请求都重新获取资源 | |
到期时间 | max-age=600 | 资源在 600 秒内有效 |
s-maxage=3600 | 共享缓存(如代理服务器)的过期时间,优先级高于 max-age | |
重新验证策略 | must-revalidate | 缓存过期后必须向服务器验证,否则不可使用 |
immutable(实验性) | 资源内容永久不变,无需验证(仅 HTTPS 场景有效) |
Last-Modified: Mon, 10 Jun 2024 12:00:00 GMT
ETag: "5f3b2a1e1c4b3a2d4c5a"
const express = require('express');
const fs = require('fs');
const crypto = require('crypto');
const app = express();
const md5 = (data) => crypto.createHash('md5').update(data).digest('hex');
app.get('/static/:file', (req, res) => {
const file = `./static/${req.params.file}`;
fs.readFile(file, 'utf8', (err, data) => {
if (err) return res.status(500).send('错误');
// 生成ETag
const currentEtag = md5(data);
// 获取浏览器携带的ETag
const ifNoneMatch = req.headers['if-none-match'];
if (ifNoneMatch === currentEtag) {
res.status(304).end(); // 资源未更新,返回304
return;
}
// 资源更新,返回新内容和ETag
res.setHeader('ETag', currentEtag);
res.send(data);
});
});
app.listen(3031);
到任何有关部署 HTTPS 或 HTTP/2 的问题,都推荐先用 Qualys SSL Labs SSL Server Test 跑个测试,大部分问题都能被诊断出来。
每个HTTP请求和响应都会带有相应的头部信息。默认情况下,在发送XHR请求的同时,还会发送下列头部信息: Accept、Accept-Charset、Accept-Encoding、Connection、Host
HTTP状态码是用以表示网页服务器HTTP响应状态的3位数字代码,其中第一位数字表示响应类别,响应类别从1到5分为五种,分别代表:临时响应、成功、重定向、请求错误、服务器错误。
在客户端与服务器数据传输的过程中,HTTP协议的传输是不安全的,也就是一般情况下HTTP是明文传输的。但HTTPS协议的数据传输是安全的,也就是说HTTPS数据的传输是经过加密的
在最早的时候,第一个定稿的http协议是http/0.9版本,在这个版本里面,http协议,它的内容,非常非常的简单 只有一个命令。http协议的历史,其中当然还有https,https是http的安全版本,它实际使用的内容跟http/1.1没有很大的区别
Axios 是一个基于 promise 的 HTTP 库 ,使用了axios来进行数据的请求,一般都需要我们对它进行封装处理。下面简单介绍下如何对axios的二次封装的实现,以及在vue中的使用。
设置ConnectionPoolTimeout:这定义了从ConnectionManager管理的连接池中取出连接的超时时间,此处设置为1秒。设置ConnectionTimeout:这定义了通过网络与服务器建立连接的超时时间。Httpclient包中通过一个异步线程去创建与服务器的socket连接
X-Forwarded-For一般是每一个非透明代理转发请求时会将上游服务器的IP地址追加到X-Forwarded-For的后面,使用英文逗号分割;X-Real-IP一般是最后一级代理将上游IP地址添加到该头中;X-Forwarded-For是多个IP地址,而X-Real-IP是一个
HTTP协议是基于请求/响应模式的,因此只要服务端给了响应,本次HTTP连接就结束了,根本没有长连接这一说。网络上说HTTP分为长连接和短连接,其实本质上是说的TCP连接。TCP连接是一个双向的通道,它是可以保持一段时间不关闭的,因此TCP连接才有真正的长连接和短连接这一说。
一些常见的状态码为:200 - 服务器成功返回网页;404 - 请求的网页不存在;503 - 服务不可用。1xx(临时响应):表示临时响应并需要请求者继续执行操作的状态代码。2xx (成功):表示成功处理了请求的状态代码。
内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!