简介:什么是用户代理减少和客户端提示?
近年来,隐私问题推动了浏览器处理用户代理字符串的方式发生了重大变化。传统上用于识别浏览器和设备信息的用户代理字符串已被减少以限制共享的信息量,从而保护用户隐私。为了解决减少用户代理的局限性,客户端提示作为一种解决方案应运而生,提供了一种更加受控且尊重隐私的方式来共享必要的信息。
在这里阅读完整的博客文章
用户代理字符串简史
user-agent 字符串可以追溯到网络浏览器的早期,从 tim berners-lee 的 worldwideweb 开始。最初,它们很简单,提供基本的浏览器和版本信息。随着时间的推移,它们逐渐演变为包含有关操作系统、设备类型等的详细数据,事实证明这对于网络分析和优化用户体验非常有用。然而,这个细节也启用了设备指纹识别,引发了隐私问题。
什么是用户代理减少?
减少user-agent的目的是尽量减少user-agent字符串中的信息,以保护用户隐私。减少了特定操作系统版本和硬件型号等高熵信息。例如,google 的 chrome 现在报告不太详细的 user-agent 字符串:
- 之前:mozilla/5.0(linux;android 13;pixel 7)applewebkit/537.36(khtml,如 gecko)chrome/95.2.1.0 mobile safari/537.36
- 之后:mozilla/5.0(linux;android 10;k)applewebkit/537.36(khtml,如 gecko)chrome/95.0.0.0 mobile safari/537.36
类似地,firefox 和 safari 也实现了自己版本的 user-agent 减少,尽管基于其独特的策略略有不同。
客户端提示如何发挥作用?
客户端提示提供了一种以注重隐私的方式请求有关用户设备和浏览器的特定高熵信息的方法。访问客户端提示有两种主要方法:
- http 请求标头: 网站可以使用 http 请求标头请求有关用户浏览器和设备的特定信息。这通常用于第一方环境,确保详细的用户信息只能通过主网站访问,而不能通过第三方资源访问。
- javascript api: 客户端提示也可以通过 javascript 中的 navigator.useragentdata 对象访问。这允许动态查询特定信息,例如架构、模型和平台版本,而无需设置额外的标头。
实施客户端提示
使用 http 请求标头
要通过 http 标头实现客户端提示,服务器需要在 http 响应中设置适当的标头,通知浏览器在将来的请求中包含这些提示。例如:
accept-ch: sec-ch-ua-platform-version
网友留言2