聊聊浏览器指纹

Canvas 指纹

许多网站和跟踪软件使用HTML画布指纹来区分和追踪用户。这是通过利用不同浏览器和设备在绘制图像时产生微小差异的原理实现的。不同浏览器采用不同的图像处理引擎、导出选项和压缩级别,因此每台电脑绘制的图片都会略有不同。这些微小差异可以用来为用户设备分配特定的指纹,并且还可以用来识别不同的用户

javascript 复制代码
function getCanvasFingerStr() {    
    var canvas = document.createElement('canvas');    
    var context = canvas.getContext("2d");    
    context.font = "18pt Arial";    
    context.textBaseline = "top";    
    context.fillText("Helloword", 2, 2);    
    return canvas.toDataURL("image/jpeg");
}
getCanvasFingerStr()

推荐

fingerprint2.min.js

‌**Fingerprint2JS** ‌是一个用于收集用户设备指纹信息的JavaScript库,通过获取用户的硬件和软件信息来生成唯一的标识符。它主要用于判断用户是否是新增用户或者设备是否为新增访问设备。Fingerprint2JS通过收集用户浏览器和设备的多种属性(如用户代理、屏幕分辨率、插件列表、字体、CanvasWebGL特性等)来生成一个独特的标识符,用于识别和区分用户‌1。

技术原理

  1. 信息收集‌:

    • 浏览器特性检测‌:获取用户的浏览器类型、版本、语言、是否支持特定API等。
    • 硬件特征‌:包括屏幕尺寸、颜色深度、时间戳偏移等。
    • 字体检测‌:通过对一系列随机字符串进行渲染并测量宽度,识别出已安装的字体集。
    • WebGL指纹‌:利用WebGL的渲染信息,通常包含GPU信息,是设备独一无二的标志之一。
    • 音频指纹‌:通过播放特定音频文件并捕获其响应来生成音频指纹‌12。
  2. 指纹生成 ‌:所有收集的数据最后通过一个哈希函数(如SHA-1)处理,生成唯一指纹。这个指纹可以作为识别用户的一种方式,即使他们清除cookies或者更换设备,只要浏览器配置保持不变,就能被识别出来‌12。

使用示例

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Fingerprint2JS Example</title>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/fingerprintjs2/2.1.0/fingerprint2.min.js"></script>
</head>
<body>
    <h1>Fingerprint2JS Example</h1>
    <script>
        Fingerprint2.get(function (components) {
            console.log(components); // 打印各字段代表的含义
            const values = components.map((component) => component.value);
        });
    </script>
</body>
</html>

以下是一个简单的使用示例,演示了如何在HTML页面中引入Fingerprint2JS库并生成设备指纹:

https://cdnjs.cloudflare.com/ajax/libs/fingerprintjs2/2.1.0/fingerprint2.min.js

相关推荐
海天胜景13 分钟前
vue3 获取选中的el-table行数据
javascript·vue.js·elementui
翻滚吧键盘33 分钟前
vue绑定一个返回对象的计算属性
前端·javascript·vue.js
苦夏木禾37 分钟前
js请求避免缓存的三种方式
开发语言·javascript·缓存
超级土豆粉1 小时前
Turndown.js: 优雅地将 HTML 转换为 Markdown
开发语言·javascript·html
秃了也弱了。1 小时前
Chrome谷歌浏览器插件ModHeader,修改请求头,开发神器
前端·chrome
乆夨(jiuze)1 小时前
记录H5内嵌到flutter App的一个问题,引发后面使用fastClick,引发后面input输入框单击无效问题。。。
前端·javascript·vue.js
忧郁的蛋~2 小时前
HTML表格导出为Excel文件的实现方案
前端·html·excel
小彭努力中2 小时前
141.在 Vue 3 中使用 OpenLayers Link 交互:把地图中心点 / 缩放级别 / 旋转角度实时写进 URL,并同步解析显示
前端·javascript·vue.js·交互
然我2 小时前
别再只用 base64!HTML5 的 Blob 才是二进制处理的王者,面试常考
前端·面试·html
NanLing2 小时前
【纯前端推理】纯端侧 AI 对象检测:用浏览器就能跑的深度学习模型
前端