技术场景

常用于广告联盟

例如在某个网站上看过某个商品,但没有登录过,过两天用同台电脑访问其他网站时,却发现很多同类商品的广告

实现方式

旧方式

在过去可能使用cookie去追踪用户信息,但cookie可以被用户禁止掉,从而无法追踪,并且无法跨域访问

或者使用浏览器指纹(navigator),它包含:

  • userAgent(用户代理)
    1
    2
    // 包含系统、浏览器版本等信息
    "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/114.0.0.0 Safari/537.36 Edg/114.0.1823.58"
  • language(浏览器的语言)"zh-CN"
  • platform(操作系统)"Win32"

等信息,但这些指纹不能对某个人进行唯一性标识,也无法对客户端进行唯一性判定

基于HTML5的诸多高级指纹对此提供了新思路

canvas指纹

canvas可以绘制一些图形,游戏等,但它也可以用来跟踪用户

调用toDataURL转换base64时,他底层会获取设备,操作系统,浏览器,三合一的唯一标识

三种条件并非无法同时复现,所以canvas指纹并非唯一,但重复概率也已经很小了

生成canvas指纹

1
2
3
4
5
6
7
8
const uuid = () => {
const canvas = document.createElement('canvas');
const ctx = canvas.getContext('2d');
const txt = 'test';
ctx.fillText(txt, 10, 10)
console.log(canvas.toDataURL())
return md5(canvas.toDataURL())
}

生成的Base64(edge):

1


生成的Base64(chrome):

1


两个浏览器生成的base64串不同,但图片是一样的

如果base64太长,可以进行MD5压缩或crypto

防止跟踪

安装随机修改canvas指纹的浏览器插件(CanvasFingerprintBlock)

原理:每次随机往canvas画布里注入一个随机的噪音(肉眼是看不到的),从而影响base64加密结果