一、什么是浏览器指纹?

浏览器指纹是指网站通过浏览器的各种信息,如系统字体、屏幕分辨率、浏览器插件等技术定位一个用户,就算使用浏览器的隐私窗口模式,也无法匿名。这是一个被动的识别方式。也就是说,理论上你访问了某一个网站,那么这个网站就能识别到你,虽然不知道你是谁,但你有一个唯一的指纹,将来无论是广告投放、精准推送,还是其他一些关于隐私的事情,都非常方便。另外,不要迷信隐身模式,那个不行的。而 Chrome 与 Firefox 扩展可以持续记录你的浏览器指纹,让你观察到一些变化。

二、浏览器指纹实现技术有哪些?

0)一般指纹

Cookies
Cookie 并不是它的原意“甜饼”的意思, 而是网站为了辨别用户身份,保存在浏览器中的简单的文本信息,当客户再次访问这个网站,这些信息可供该网站读取使用。例如,你进入一个网站,输入用户名密码登陆之后,一般可以选择"自动登陆",下次从同台电脑再进入这个网站就不用输入用户名密码了。这个过程,实际上是第一次登陆时候,浏览器中保存了这个网站的cookie信息,下次再次进入这个网站时,直接读取了 cookie 信息,不需要让用户再次输入用户名密码了。Session
上面说的Cookies,有一个有效期,如果超过了有效期,会被浏览器自动删除,这个有效期一般是几天或者几个月。还有一种特殊的 Cookies,有效期比较短,关闭浏览后就会失效,被称为 Session。Session一般保存客户操作的临时信息。IP
这里的IP即IP地址(Internet Protocol Address),是指互联网协议地址。你访问网站的过程有点像你向报社订阅一份报纸。例如,你发一封邮件到人民日报社,告诉报社你要订阅一份《环球时报》,报社把一份图文并茂的报纸寄送到你邮件的发件地址;这个过程里,你必须告诉报社你的收件地址。我们访问网站时候也是类似的,你的浏览器向网站网站发送一个请求,网站把相应的图片、文本、样式发送给你。你必须告诉网站你的IP地址,这个过程才能完成,而这个地址是网站识别客户的重要信息。

1) 基本指纹

基本指纹是任何浏览器都具有的特征标识,比如硬件类型(PC/Phone)、操作系统(Windows/macOS)、用户代理(User agent)、系统字体、语言、屏幕分辨率、浏览器插件 (Flash, Silverlight, Java, etc)、浏览器扩展、浏览器设置 (Do-Not-Track, etc)、时区差(Browser GMT Offset)等众多信息,这些指纹信息“类似”人类的身高、年龄等,有很大的冲突概率,只能作为辅助识别。可以在该网址进行查看本地浏览器的基本特征,zllp.myyxxx_xzrl=.g:/wkx.?w_okg/

2) 高级指纹

基本指纹就像是人的外貌特征,外貌可以用男女、身高、体重区分,然而这些特征不能对某个人进行唯一性标识,仅使用基本指纹也无法对客户端进行唯一性判定,基于HTML5的诸多高级指纹对此提供了新思路。

①、Canvas指纹

说到高级指纹,不得不提Canvas指纹,Canvas(画布)是HTML5中一种动态绘图的标签,可以使用其生成甚至处理高级图片。
Canvas指纹的原理大致如下:
相同的HTML5 Canvas元素绘制操作,在不同操作系统、不同浏览器上,产生的图片内容不完全相同。在图片格式上,不同浏览器使用了不同的图形处理引擎、不同的图片导出选项、不同的默认压缩级别等。在像素级别来看,操作系统各自使用了不同的设置和算法来进行抗锯齿和子像素渲染操作。即使相同的绘图操作,产生的图片数据的CRC检验也不相同。
在线测试地址:zllp.myyxxx_/wkx.?wd?r-._okgyorsbr. 。

②、AudioContext指纹

HTML5提供给JavaScript编程用的Audio API则让开发者有能力在代码中直接操作原始的音频流数据,对其进行任意生成、加工、再造,诸如提高音色,改变音调,音频分割等多种操作,甚至可称为网页版的Adobe Audition。
AudioContext指纹原理大致如下:
方法一:生成音频信息流(三角波),对其进行FFT变换,计算SHA值作为指纹,音频输出到音频设备之前进行清除,用户毫无察觉。
方法二:生成音频信息流(正弦波),进行动态压缩处理,计算MD5值。
AudioContext指纹基本原理:
主机或浏览器硬件或软件的细微差别,导致音频信号的处理上的差异,相同器上的同款浏览器产生相同的音频输出,不同机器或不同浏览器产生的音频输出会存在差异。
从上可以看出AudioContext和Canvas指纹原理很类似,都是利用硬件或软件的差异,前者生成音频,后者生成图片,然后计算得到不同哈希值来作为标识。音频指纹测试地址:https://audiofingerpw=sl_kp?sxpg_okg/

3) 硬件指纹

硬件指纹主要通过检测硬件模块获取信息,作为对基于软件的指纹的补充,主要的硬件模块有:GPU、摄像头、扬声器/麦克风、运动传感器、GPS、电池、CPU、网卡、蓝牙、BOIS等。

4) 综合指纹

①、Web世界的指纹碰撞不可避免,将上述所有的基本指纹和多种高级指纹综合利用,进行分析、计算哈希值作为综合指纹,可以大大降低碰撞率,极大提高客户端唯一性识别的准确性。测试地址:https://panopticlick.eff.org/

②、跨浏览器指纹、上述指纹都是基于浏览器进行的,同一台电脑的不同浏览器具有不同的指纹信息。这样造成的结果是,当同一用户使用同一台电脑的不同浏览器时,服务方收集到的浏览器指纹信息不同,无法将该用户进行唯一性识别,进而无法有效分析改用户的的行为。近期有学者研究了一种跨浏览器的浏览器指纹,其依赖于浏览器与操作系统和硬件底层进行交互进而分析计算出指纹,这种指纹对于同一台电脑的不同浏览器也是相同的。更多技术细节请参考:
http://yinzhicao.org/TrackingFree/crossbrowsertracking_NDSS17.pdf

③、WebRTC(网页实时通信,Web Real Time Communication),是一个开源项目,旨在使得浏览器能为实时通信(RTC)提供简单的JavaScript接口,说的简单明了一点就是让浏览器提供JS的即时通信接口,让浏览器实时获取和交换视频、音频和数据。WebRTC实现了三个API,分别是:MediaStream:通过MediaStream的API能够通过设备的摄像头及麦克风获得视频、音频的同步流。RTCPeerConnection:RTCPeerConnection是WebRTC用于构建点对点之间稳定、高效的流传输的组件。RTCDataChannel:RTCDataChannel使得浏览器之间(点对点)建立一个高吞吐量、低延时的信道,用于传输任意数据。基于WebRTC的实时通讯功能,可以获取客户端的IP地址,包括本地内网地址和公网地址。其原理是利用到RTCPeerConnection 的API,大致函数如下:利用WebRTC能做的事情还远不止这些,比如使用其探测扫描内网信息,进行语音、视频交流,更多技术细节请参考:
zllpmyys?l_=pordf_okg

三、浏览器指纹有什么作用?

类似人的外貌和指纹,Web客户端(这里主要指浏览器)也有多种“外貌”信息和“指纹”信息,将这些信息综合分析计算后,可对客户端进行唯一性识别,进而锁定、追踪、了解网民行为和隐私数据。用于广告投递、用户兴趣分析等,进而作为决策的依据,利用Web客户端对用户行为进行收集和追踪是重要手段之一。

五、怎么实现浏览器指纹?

①、FingerprintJS 是一个快速的浏览器指纹库,纯 JavaScript 实现,没有依赖关系。默认情况下,使用 Murmur Hash 算法返回一个32位整数。Hash 函数可以很容易地更换。
https://c=lzi/_okg/Valve/fingerprintjs

②、Fingerprintjs2是FingerprintJS的升级版
https://c=lzi/_okg/Valve/fingerprintjs2

六、检测浏览器指纹工具

①、AmIUnique – 侦测你的「浏览器指纹」,并显示Web/Chrome/Firefox历史记录、网址:
https://amiunique.org/

②、 Browserprint 检测可能唯一的「浏览器指纹」、网址:
https://browserprint.info/

③、Panopticlick工具可以查看浏览器的指纹、网址:
https://panopticlick.eff.org/

七、防止浏览器指纹检测方法

①、Ghostery,个人使用推荐,官网地址:
zllp.myyxxx_czk.l?w:_okg/try-us/download-browser-extension

②、Privacy Badger,官网地址:
zllp.myyxxx_eff.org/privacybadger/

③、uMatrix(仅Chrome和FireFox):
https://addons.mozilla.org/en-us/firefox/addon/umatrix/

④、NoScript(仅FireFox):
https://addons.mozilla.org/en-US/firefox/addon/noscript/#

⑤、Chameleon(仅Chrome):
https://c=lzi/_okg/ghostwords/chameleon

八、 防客户端追踪措施

使用隐身模式,目前主流的浏览器都支持该模式。


禁用WebRTC,如Firefox浏览器:打开about:config,找到media.peerconnection.enabled的项,设置成 false


禁用Geolocation
Firefox浏览器:打开about:config,找到geo.enabled 的值,设置其值为 false。
Chrome 点击设置(Settings),从显示高级设置(Show advanced settings)上,找到隐私(Privacy)并且点击内容设置(Content settings), 在窗口里找到定位(Location)并设置选项不允许任何网站追踪你的物理位置(Do not allow any site to track your physical location)
限制API访问文件资源时序信息,恶意网站会通过检测浏览器缓存的时序信息,包括访问和忽略第三方网站的资源,来判断使用者是否访问过第三方网站。

使用指纹浏览器
目前市面有很多指纹浏览器,例如:云雀浏览器海豚浏览器

原文来自邦阅网 (52by.com) - www.52by.com/article/91688

声明:该文观点仅代表作者本人,邦阅网系信息发布平台,仅提供信息存储空间服务,若存在侵权问题,请及时联系邦阅网或作者进行删除。

评论
登录 后参与评论
发表你的高见