当前位置: 首页 > article >正文

HTTP 之 HTTP头部优化策略(九)

1. 缓存控制(Cache-Control):

使用Cache-Control头部来告诉浏览器如何缓存响应。
例如,Cache-Control: max-age=3600表示资源在一个小时后过期。
对于不经常变化的资源,如CSS、JavaScript文件和图片,可以设置更长的过期时间。

//服务器端设置缓存控制(使用Apache为例)
<IfModule mod_expires.c>
  ExpiresActive on
  ExpiresByType image/jpg "access plus 1 year"
  ExpiresByType image/jpeg "access plus 1 year"
  ExpiresByType image/gif "access plus 1 year"
  ExpiresByType image/png "access plus 1 year"
  ExpiresByType text/css "access plus 1 month"
  ExpiresByType application/javascript "access plus 1 month"
</IfModule>

2. 内容编码(Content-Encoding):

使用Content-Encoding头部启用压缩,如gzip或deflate,减少传输的数据量。

3. ETag和Last-Modified:

ETag和Last-Modified头部用于验证缓存,如果资源未改变,服务器可以返回304 Not Modified状态码,告知浏览器使用本地缓存的副本。

//nginx
location ~* \.(jpg|jpeg|png|gif|ico)$ {
  etag on;
}

4. 预加载(Preloading):

使用Link头部的rel="preload"属性预加载关键资源,如首屏渲染所需的字体或脚本。

//预加载关键资源(HTML中使用):
<link rel="preload" href="style.css" as="style">
<link rel="preload" href="script.js" as="script">

5. DNS预解析(DNS-Prefetch):

使用Link头部的rel="dns-prefetch"属性提前解析第三方域名的DNS,减少第三方脚本或资源加载的延迟。

//DNS预解析(HTML头部使用):
<link rel="dns-prefetch" href="//example.com">

6. 预连接(Preconnect):

使用Link头部的rel="preconnect"属性提前建立与关键第三方域的连接。

// 预连接(HTML头部使用):
<link rel="preconnect" href="https://cdn.example.com">

7. 预渲染(Prerender):

使用Link头部的rel="prerender"属性让浏览器预渲染页面,这适用于预计用户很快就会访问的页面。

8. 服务端推送(Server Push):

HTTP/2引入了服务端推送,允许服务器在客户端请求之前主动发送资源。

9. 优化资源(Optimize Resources):

使用Accept-Ranges头部支持资源的按范围请求,允许浏览器请求资源的一部分。

10. Vary头部:

Vary头部告知代理服务器考虑使用缓存的响应是否与请求的头部匹配。

11. 连接保持活动(Keep-Alive):

Connection: keep-alive头部用于保持TCP连接打开,减少连接建立和关闭的开销。

12. 跨域资源共享(CORS):

正确配置Access-Control-Allow-Origin和其他CORS相关的头部,确保资源可以被正确地跨域访问。

//设置CORS头部(服务器配置示例):
location / {
  add_header 'Access-Control-Allow-Origin' '*';
  # 或者指定特定域名
  # add_header 'Access-Control-Allow-Origin' 'https://www.example.com';
}

13. 安全策略(Content-Security-Policy):

使用Content-Security-Policy头部减少XSS攻击的风险。

// 设置内容安全策略(HTML头部使用):
<meta http-equiv="Content-Security-Policy" content="default-src 'self'; script-src 'self' https://trusted.cdn.com; object-src 'none';">

14. 节省带宽(节省资源请求):

使用Accept头部告知服务器客户端支持的数据格式,减少不必要的数据传输。

//使用Accept头部(客户端请求示例,使用JavaScript):
fetch('https://api.example.com/data', {
  headers: {
    'Accept': 'application/json',
  },
});

15. HTTP/2和HTTP/3:

利用HTTP/2的多路复用减少连接数,利用HTTP/3的QUIC减少连接建立时间和提高传输效率。

//使用HTTP/2服务端推送(服务器配置):
# 这通常是在服务器配置中自动处理的,例如在Nginx中:
http2_push /path/to/pushed.css;

http://www.kler.cn/a/288096.html

相关文章:

  • vue 获取摄像头拍照,并旋转、裁剪生成新的图片
  • C++的一些模版
  • react 中 memo 模块作用
  • LeetCode654.最大二叉树
  • Uniapp踩坑input自动获取焦点ref动态获取实例不可用
  • 从0开始学习--Day26--聚类算法
  • Spring Boot 整合 Sentinel 实现流量控制
  • Facebook的AI革新:如何利用人工智能提升你的社交体验
  • Golang 教程5——函数02(时间函数、内建函数、错误机制)
  • 海外云手机实现海外社媒矩阵营销
  • 计算机网络(八股文)
  • 国内可以免费使用的gpt网站【九月持续更新】
  • 浏览器按F12进入开发者模式后频繁因为异常而暂停导致无法分析页面xpath
  • 企业财税自动化解决方案的优势与应用
  • 幂等的通用实现方案
  • Oracle rac 修改vip scan ip
  • 栈和队列算法题
  • zeppline如何配置用户登陆
  • 【Tools】如何评价黑悟空这款游戏
  • 等保测评:如何有效进行安全事件响应
  • 车辆远控功能自动化测试方案:打造高效可靠的测试流程
  • 每天一个数据分析题(五百一十三)- 决策树算法
  • 基于深度学习的稀疏训练
  • JSON的基础使用
  • 去中心化身份验证:Web3时代数字身份的革新
  • 网络安全售前入门10安全服务——安全培训服务