【浏览器指纹】fingerprintjs2使用fingerprintjs生成浏览器唯一标识(浏览器指纹)

本文主要是介绍【浏览器指纹】fingerprintjs2使用fingerprintjs生成浏览器唯一标识(浏览器指纹),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 什么是浏览器指纹?
  • fingerprintjs2
    • fingerprintjs2简介
    • 技术分析
  • 如何使用fingerprintjs2?
  • 参考文章
  • 🚀写在最后

什么是浏览器指纹?

浏览器指纹我们可以理解成是一个用户设备的浏览器的唯一id(有点类似手机设备的IMEI),通过浏览器指纹,我们可以做一些埋点操作或者是鉴权,辨别是否是同一用户,其是否有更换设备(更换浏览器)等。

fingerprintjs2

在这里插入图片描述

fingerprintjs2是通过设备浏览器信息获取浏览器指纹的插件,FingerprintJS是一种用于创建浏览器指纹的开源库,广泛用于在线安全和欺诈检测。以下是FingerprintJS如何工作:

  1. 信息收集:FingerprintJS会收集用户浏览器和设备的各种信息,包括硬件特性、浏览器设置、插件、字体、屏幕分辨率等。
  2. 指纹生成:通过对收集到的信息进行加密哈希处理,生成一个独特的浏览器指纹。
  3. 应用实例:在线支付平台和电商网站使用FingerprintJS来检测异常活动和防止欺诈。例如,当同一个账户在短时间内从不同的设备或浏览器指纹登录时,系统会标记为可疑活动,触发安全警报。

fingerprintjs2简介

Fingerprint.js的核心理念是在用户不知情且不侵犯其隐私的情况下,收集一些浏览器的基本信息,如屏幕分辨率、时区、已安装字体、插件等,并将这些数据转化为一个哈希值,即所谓的"设备指纹"。这种指纹可以作为识别用户的一种方式,即使他们清除cookies或者更换设备,只要浏览器配置保持不变,就能被识别出来。

技术分析

Fingerprint.js使用了一系列的技术来生成设备指纹:

1、浏览器特性检测:它获取了用户的浏览器类型、版本、语言、是否支持特定API等。
2、硬件特征:包括屏幕尺寸、颜色深度、时间戳偏移等。
3、字体检测:通过对一系列随机字符串进行渲染并测量宽度,识别出已安装的字体集。
4、 WebGL指纹:利用WebGL的渲染信息,这通常包含GPU信息,是设备独一无二的标志之一。
5、 所有收集的数据最后通过一个哈希函数(SHA-1)处理,生成唯一指纹。

该库具有良好的兼容性,可以在多种现代浏览器中运行,并且提供了简单易用的API,使得集成到任何项目中变得容易。

如何使用fingerprintjs2?

安装

npm install @fingerprintjs/fingerprintjs  或者  yarn add @fingerprintjs/fingerprintjs

引用

import FingerprintJS from '@fingerprintjs/fingerprintjs';
methods: {async getFingerprint() {// 初始化FingerprintJSconst fp = await FingerprintJS.load()// 获取访问者的指纹const result = await fp.get()// 配置const {osCpu,webGlBasics,languages,audioBaseLatency,reducedTransparency,vendor,vendorFlavors,fonts,fontPreferences,plugins,forcedColors,domBlockers,pdfViewerEnabled,audio,canvas,webGlExtensions,math,...components} = result.componentsconst extendedComponents = {...components}const fingerprintId = FingerprintJS.hashComponents(extendedComponents)console.log('extendedComponents*-*-*-*-*-*-*-         ', extendedComponents)console.log('fingerprintId*-*-*-*-*-*-*-         ', fingerprintId)// this.deviceNo = fingerprintId},

在这里插入图片描述
配置项解析:

Excludes为{}时将包含即不会排除以下组件(源码)

var components = [
{key: ‘userAgent’, getData: UserAgent},//用户代理
{key: ‘webdriver’, getData: webdriver },//网页内驱动软件
{key: ‘language’, getData: languageKey},//语言种类
{key: ‘colorDepth’, getData: colorDepthKey}, //目标设备或缓冲器上的调色板的比特深度
{key: ‘deviceMemory’, getData: deviceMemoryKey},//设备内存
{key: ‘pixelRatio’, getData: pixelRatioKey},//设备像素比
{key: ‘hardwareConcurrency’, getData: hardwareConcurrencyKey},//可用于运行在用户的计算机上的线程的逻辑处理器的数量。
{key: ‘screenResolution’, getData: screenResolutionKey}, //当前屏幕分辨率
{key: ‘availableScreenResolution’, getData: availableScreenResolutionKey},//屏幕宽高(空白空间)
{key: ‘timezoneOffset’, getData: timezoneOffset},//本地时间与 GMT 时间之间的时间差,以分钟为单位
{key: ‘timezone’, getData: timezone},//时区
{key: ‘sessionStorage’, getData: sessionStorageKey},//是否会话存储
{key: ‘localStorage’, getData: localStorageKey},//是否具有本地存储
{key: ‘indexedDb’, getData: indexedDbKey},//是否具有索引DB
{key: ‘addBehavior’, getData: addBehaviorKey},//IE是否指定AddBehavior
{key: ‘openDatabase’, getData: openDatabaseKey},//是否有打开的DB
{key: ‘cpuClass’, getData: cpuClassKey},//浏览器系统的CPU等级
{key: ‘platform’, getData: platformKey},//运行浏览器的操作系统和(或)硬件平台
{key: ‘doNotTrack’, getData: doNotTrackKey},//do-not-track设置
{key: ‘plugins’, getData: pluginsComponent},//浏览器的插件信息
{key: ‘canvas’, getData: canvasKey},//使用 Canvas 绘图
{key: ‘webgl’, getData: webglKey},//WebGL指纹信息
{key: ‘webglVendorAndRenderer’, getData: webglVendorAndRendererKey},//具有大量熵的WebGL指纹的子集
{key: ‘adBlock’, getData: adBlockKey},//是否安装AdBlock
{key: ‘hasLiedLanguages’, getData: hasLiedLanguagesKey},//用户是否篡改了语言
{key: ‘hasLiedResolution’, getData: hasLiedResolutionKey},//用户是否篡改了屏幕分辨率
{key: ‘hasLiedOs’, getData: hasLiedOsKey}, //用户是否篡改了操作系统
{key: ‘hasLiedBrowser’, getData: hasLiedBrowserKey}, //用户是否篡改了浏览器
{key: ‘touchSupport’, getData: touchSupportKey},//触摸屏检测和能力
{key: ‘fonts’, getData: jsFontsKey, pauseBefore: true}, //使用JS/CSS检测到的字体列表
{key: ‘fontsFlash’, getData: flashFontsKey, pauseBefore: true}, //已安装的Flash字体列表
{key: ‘audio’, getData: audioKey},//音频处理
{key: ‘enumerateDevices’, getData: enumerateDevicesKey} //可用的多媒体输入和输出设备的信息。
]

注释
在这里插入图片描述
项目地址:https://gitcode.com/fingerprintjs/fingerprintjs

参考文章

FingerprintJS生成浏览器指纹
fingerprintjs2官方文档
浏览器:浏览器指纹
前端使用fingerprintjs2获取浏览器指纹
关于FingerprintJS生成浏览器指纹UUID,同一浏览器多开下UUID不同造成的问题
Fingerprintjs2 浏览器 设备指纹 改源码

🚀写在最后

希望我的分享能够帮助到更多的人,如果觉得我的分享有帮助的话,请大家一键三连支持一下哦~
❤️原创不易,期待你的关注与支持~
点赞👍+收藏⭐️+评论✍️
😊之后我会继续更新前端学习小知识,关注我不迷路~

这篇关于【浏览器指纹】fingerprintjs2使用fingerprintjs生成浏览器唯一标识(浏览器指纹)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1054120

相关文章

Java中流式并行操作parallelStream的原理和使用方法

《Java中流式并行操作parallelStream的原理和使用方法》本文详细介绍了Java中的并行流(parallelStream)的原理、正确使用方法以及在实际业务中的应用案例,并指出在使用并行流... 目录Java中流式并行操作parallelStream0. 问题的产生1. 什么是parallelS

Linux join命令的使用及说明

《Linuxjoin命令的使用及说明》`join`命令用于在Linux中按字段将两个文件进行连接,类似于SQL的JOIN,它需要两个文件按用于匹配的字段排序,并且第一个文件的换行符必须是LF,`jo... 目录一. 基本语法二. 数据准备三. 指定文件的连接key四.-a输出指定文件的所有行五.-o指定输出

Linux jq命令的使用解读

《Linuxjq命令的使用解读》jq是一个强大的命令行工具,用于处理JSON数据,它可以用来查看、过滤、修改、格式化JSON数据,通过使用各种选项和过滤器,可以实现复杂的JSON处理任务... 目录一. 简介二. 选项2.1.2.2-c2.3-r2.4-R三. 字段提取3.1 普通字段3.2 数组字段四.

Linux kill正在执行的后台任务 kill进程组使用详解

《Linuxkill正在执行的后台任务kill进程组使用详解》文章介绍了两个脚本的功能和区别,以及执行这些脚本时遇到的进程管理问题,通过查看进程树、使用`kill`命令和`lsof`命令,分析了子... 目录零. 用到的命令一. 待执行的脚本二. 执行含子进程的脚本,并kill2.1 进程查看2.2 遇到的

详解SpringBoot+Ehcache使用示例

《详解SpringBoot+Ehcache使用示例》本文介绍了SpringBoot中配置Ehcache、自定义get/set方式,并实际使用缓存的过程,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录摘要概念内存与磁盘持久化存储:配置灵活性:编码示例引入依赖:配置ehcache.XML文件:配置

Java 虚拟线程的创建与使用深度解析

《Java虚拟线程的创建与使用深度解析》虚拟线程是Java19中以预览特性形式引入,Java21起正式发布的轻量级线程,本文给大家介绍Java虚拟线程的创建与使用,感兴趣的朋友一起看看吧... 目录一、虚拟线程简介1.1 什么是虚拟线程?1.2 为什么需要虚拟线程?二、虚拟线程与平台线程对比代码对比示例:三

k8s按需创建PV和使用PVC详解

《k8s按需创建PV和使用PVC详解》Kubernetes中,PV和PVC用于管理持久存储,StorageClass实现动态PV分配,PVC声明存储需求并绑定PV,通过kubectl验证状态,注意回收... 目录1.按需创建 PV(使用 StorageClass)创建 StorageClass2.创建 PV

Redis 基本数据类型和使用详解

《Redis基本数据类型和使用详解》String是Redis最基本的数据类型,一个键对应一个值,它的功能十分强大,可以存储字符串、整数、浮点数等多种数据格式,本文给大家介绍Redis基本数据类型和... 目录一、Redis 入门介绍二、Redis 的五大基本数据类型2.1 String 类型2.2 Hash

Redis中Hash从使用过程到原理说明

《Redis中Hash从使用过程到原理说明》RedisHash结构用于存储字段-值对,适合对象数据,支持HSET、HGET等命令,采用ziplist或hashtable编码,通过渐进式rehash优化... 目录一、开篇:Hash就像超市的货架二、Hash的基本使用1. 常用命令示例2. Java操作示例三

Linux创建服务使用systemctl管理详解

《Linux创建服务使用systemctl管理详解》文章指导在Linux中创建systemd服务,设置文件权限为所有者读写、其他只读,重新加载配置,启动服务并检查状态,确保服务正常运行,关键步骤包括权... 目录创建服务 /usr/lib/systemd/system/设置服务文件权限:所有者读写js,其他