正如手指指纹一样,当我们浏览网页,访问网站的时候,也会留下自己的独特的个人信息。浏览器指纹识别是指网站用于收集信息的跟踪技术。
网站通过该技术收集信息,如操作系统、浏览器版本、浏览器使用的语言、所在的时区、屏幕分辨率、电脑安装的字体等等。然后再将这些信息拼接、整合在一起,就可以形成独特的在线指纹,也叫浏览器指纹。每个用户的浏览器指纹都是与众不同的,在互联网上几乎不可能找到一样的浏览器指纹。
正是由于浏览器指纹的唯一性,即使在数十亿的庞大的互联网人群中,网站也可以精准地识别出来。目前,浏览器指纹识别技术的识别准确率在90%以上,有的甚至能达到99%。
尽管很多人可能认为匿名浏览或清除cookie
就能够避免浏览器指纹的影响,但实际上这并不能彻底解决问题。因为浏览器指纹技术是基于前端技术实现的,不是我们随随便便就能“绕过”的,需要更专业的技术才能解决问题。
浏览器指纹,顾名思义,是指通过收集和整合用户在浏览器使用过程中产生的多种信息,并结合这些信息的微小差异,生成一个独一无二的标识字符串,以此来识别和跟踪用户的在线行为。就像人类的指纹一样,浏览器指纹依靠多个细微的特征进行建模,创造出一个极其精准的标识符,可以区分不同的设备和用户身份。
浏览器指纹技术应用在许多领域,例如:
当用户访问网站的时候,用户的设备会向网站发送连接请求以显示网站的内容。目标网站可以访问和收集用户浏览器发送的相关的信息,其中就包括大量的设备信息。以下是一些常见的指纹信息:
Canvas指纹,是一种基于网页的HTML5 Canvas元素来进行用户跟踪的技术。它通过分析用户设备上Canvas元素渲染图形的独特方式,生成一个与众不同的标识符,从而实现对用户的识别和追踪。
HTML5 Canvas是网页中用于绘制图形的一个元素,它可以显示各种视觉内容,包括文本、图形和动画。不同设备的浏览器在渲染Canvas时,会因硬件和软件配置的差异而产生细微不同的结果,如文本的字体大小、线条粗细、图形的阴影效果等,Canvas指纹便是借此跟踪用户。
2012年,加州大学的研究人员Hovav Shacham和Keaton Mowery首次提出了Canvas指纹识别技术。他们发表的论文Pixel Perfect: Fingerprinting Canvas in HTML5详细阐述了如何通过HTML5的Canvas特性来识别和跟踪互联网用户。从那时起,Canvas指纹识别技术开始被广泛关注,并在随后的几年中,被越来越多的网站和网络服务提供商采用。
与传统的cookie跟踪或IP地址跟踪不同,Canvas指纹技术的独特之处在于它的隐蔽性和准确度。这一技术不依赖于用户设备上存储的任何信息,即使用户禁用了cookie或者使用了IP匿名化工具,Canvas指纹技术仍然可以有效地追踪用户的活动。它通过收集如下信息来形成用户的“指纹”:
这些收集到的数据被聚合在一起,形成了一个用户的“指纹”。由于两个用户的浏览器数据几乎不可能完全相同,因此这种技术在识别用户方面的准确率高达99%。
Canvas指纹识别技术通过HTML5的Canvas API来实现,该API允许网页通过JavaScript在网页上绘制图像和文字。当用户访问植入了Canvas指纹脚本的网站时,该脚本会在用户的浏览器上绘制带有随机字体和大小的文本,以及随机背景。然后,这些Canvas像素数据会被转换成Base64编码格式,再通过哈希函数转换成一个独特的指纹。
不同的计算机基于各自的图像处理引擎、图像导出选项、浏览器压缩级别等因素,在图像格式层面上渲染相同的Canvas图像时会有所不同。在系统层面上,不同的操作系统可能因为使用了不同的字体、子像素渲染算法和抗锯齿设置,而渲染出不同的结果。
Canvas指纹依赖的数据包括:
这种技术的一大优势在于,它不会在用户系统中加载任何内容,而是利用已有的资源。为了有效工作,Canvas指纹识别需要一个数据库来存储指纹信息。当用户再次访问网站时,系统会生成一个哈希值,并将其与数据库中的指纹库进行比对,以识别回访者或新用户。
Canvas指纹识别对于互联网用户和网站所有者都具有至关重要的作用。然而,它也有一些缺点,下面我们将探讨其中的一些。
优点
缺点
字体可以成为浏览器指纹的一部分。当设备安装了特定的字体,或者没有安装某些字体,这些信息可以被用来生成设备的唯一指纹。这是因为每个人的设备上安装的字体组合可能是独特的,特别是对于安装了大量非标准字体的用户来说。因此,字体可以帮助形成一个相当独特和详细的浏览器指纹。
字体指纹主要是通过浏览器的JavaScript API来实现的。这种技术的主要原理是,浏览器可以获取并报告用户设备上可用的字体列表。这些字体列表,结合其他浏览器和设备的信息,可以形成一个相当独特的浏览器指纹。
以下是一些常用的字体指纹技术:
字体枚举:这是最直接的方法,就像查看设备上安装了哪些应用一样,网站可以查看设备上安装了哪些字体。这是通过浏览器提供的一种功能来实现的,它会返回一个包含了所有已安装字体的列表。
字体检测:这是一种更微妙的方法。网站可以让浏览器显示一段使用特定字体的文本,然后测量这段文本的大小。如果这个字体已经安装,那么这段文本的大小会有所变化,通过这种方式,网站就可以知道这个字体是否已经安装。这就像是一个试错的过程,网站尝试使用一个字体,然后看看浏览器的反应。
画布指纹:这是一种更复杂的方法。网站可以在一个虚拟的画布上绘制一段文本,然后看看这段文本的像素是如何排列的。由于不同的字体会导致像素的排列方式不同,所以网站可以通过比较这段文本的像素排列来判断您的设备上是否安装了这个字体。这就像是在一个黑板上写下一段文字,然后通过研究这段文字的笔迹来判断您使用的是什么笔。
WebGL(Web Graphics Library)是一项强大的JavaScript API,专为在浏览器中实现交互式3D和2D图形而设计。它建立在OpenGL ES(OpenGL for Embedded Systems)标准之上,利用计算机的图形处理单元(GPU)在浏览器中创造高性能的图形和视觉效果。
WebGL的独特之处在于其跨平台性,支持多种操作系统和浏览器,确保图形应用程序在各类设备上无缝运行。通过硬件加速,WebGL实现了更高效的图形渲染,使得复杂的图形和动画在浏览器中表现得更为流畅。这项技术的实时渲染能力使其在游戏开发和虚拟现实等领域广受欢迎,开发者可以创造出生动且具有交互性的图形体验。
同时,WebGL不仅用于图形渲染,还能巧妙地融合图形与数据,例如在数据可视化领域创造动态而富有交互性的图表。作为一个开放标准,WebGL得到了广泛支持和社区参与,为开发者提供了丰富的资源和文档,使其能够更好地学习和改进WebGL项目。
WebGL和Canvas是两种用于在Web浏览器中呈现图形的技术,它们之间有一些本质的区别。我们会用更通俗的语言帮你理解WebGL与Canvas之间的关系:
想象一下你在画板上画画。Canvas就像是这个画板,它提供了一个简单的方式,让你可以在上面画各种形状、颜色,做出漂亮的图案。这是一个二维的画板,就像平面上的纸一样。
现在,如果你想要在这个画板上创造更加立体、有深度感的图形,就需要WebGL登场了。WebGL就像是给你的画板添加了一个魔法,让你可以在上面创建美丽的三维效果,就像是画了一个立体的小雕塑一样。
所以,Canvas和WebGL都是用来在网页上创造各种图形的工具,只不过Canvas更适合简单的、二维的需求,而WebGL更适合复杂的、有立体感的三维图形。就好比Canvas是你的平面画板,而WebGL是能够让画面更有层次感的魔法。
js// 包含标点符号、小写、大写字符的文本
var txt = "JiangGujin,com <canvas> 1.0";
ctx.textBaseline = "top";
// 最常见的类型
ctx.font = "14px 'Arial'";
ctx.textBaseline = "alphabetic";
ctx.fillStyle = "#f60";
ctx.fillRect(102, 1, 62, 20);
// 增加渲染差异的颜色混合
ctx.fillStyle = "#069";
ctx.fillText(txt, 2, 15);
ctx.fillStyle = "rgba(102, 204, 0, 0.7)";
ctx.fillText(txt, 4, 17);
// 生成图像的Base64格式字符串
var data = canvas.toDataURL()
// 将Base64字符串转换为Uint8Array
var rawData = atob(data.split(",")[1]);
var dataArr = new Uint8Array(rawData.length);
for (let i = 0; i < rawData.length; i++) {
dataArr[i] = rawData.charCodeAt(i);
}
// 将最终的Uint8Array进行MD5摘要运算,将结果作为指纹
// https://github.com/emn178/js-md5
var hash = md5(dataArr).toUpperCase();
console.log(hash)
本文作者:蒋固金
本文链接:
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!