AdvertCN - 广告中国

 找回密码
 立即注册

QQ登录

只需一步,快速开始

 谷歌+Bing+TT+MSN官方代理 
⚡️按条S5代理⚡️静态⚡️独享⚡️5G⚡️AdsPower:安全不封号,高效自动化Mediabuy⚡️玩家开户首选
【鲁班跨境通-自助充值转账】FB/GG/TT❤️官方免费开户Affiliate 全媒体流量资源⚡️Taboola/Outbrain /Bing⚡️一级代理
开户投流-7*24h❤️人工在线【官方】❤️搜索套利买量投流开户独立站⚡️开户投放FB BM不限额,短id账单户
E.PN 虚拟卡BINOM TRACKER 60% OFF!比Adplexity还好用的Spy工具ADPLEXITY + ADVERTCN
7200W全球动态不重复住宅IP代理虚拟信用卡+独立站收款Facebook 批量上广告尤里改 - FB 稳定投放
免费黑五教程(持续更新、欢迎交流)FB 三不限源头 - 自助下户充值转款各种主页、账单户、BM户(优势)⚡️个人户,bm户不限额,账单户
FB资源,账单户,分享户,国内一手FB企业户,TT老户,GG老户源头海外CL企业户源头FB虚拟卡⚡️消费越多返现越多
【找量】BA独家Nutra单找量虚拟FB卡 ⚡️ 透明条件 国内外持牌,虚拟信用卡和收付款广告位出租
8500万高质量住宅IP,助力各种需求虚拟卡返佣1%,国内持牌机构  
查看: 11169|回复: 4

[实战] 【指纹浏览器系列】九、 编写自己的指纹浏览器以及指纹...

[复制链接]

16

主题

892

广告币

905

积分

中级会员

Rank: 3Rank: 3

积分
905

社区QQ达人

QQ
发表于 2022-4-8 20:02:03 | 显示全部楼层 |阅读模式
Lemft
本帖最后由 三分醉 于 2022-4-8 20:03 编辑
5 g+ _: A6 Q) R; \
; ^; L" u* X! W. _. @% ]% R0 s浏览器插件形式改变指纹

指纹浏览器系列教程目录:
; X1 Z# T2 R: p1 w  c/ |一、指纹浏览器的原理与应用& {  B5 e0 H/ x5 M! Q6 p8 E7 F& J2 _
二、浏览器指纹的检测与对抗的办法
- p. g1 B# o0 V. Z" {三、更多的检测手段与指纹浏览器选购方案& J/ Q) T7 O6 B; k3 M; J
四、命令行形式浏览器多开解决方案
6 p1 ?: t/ e: _) o5 I五、浏览器插件形式改变指纹
) \+ p/ z" S0 R* D* T& B* R六、node.js库Puppeteer改变浏览器指纹信息1 M% x# @# ~3 N7 |! Z, [
七、python改变浏览器指纹信息# p  q' F2 M5 {& p
八、java、go、c#、php、rust更改浏览器指纹信息* J+ c6 T7 ?. H1 V+ x
九、编写自己的指纹浏览器以及指纹信息来源5 d0 e: |2 W+ @' w5 T  f5 X$ K7 [* D" B
十、闲话聊一聊指纹浏览器的用途


% m3 V( n+ }% V! b+ j编写自己的指纹浏览器以及指纹信息的来源

少年,你想拥有独属于自己的指纹浏览器吗?耐心看完本篇文章你一定会有所收获!!!
8 H# L, y2 [  E/ x/ O0 N本文会以开源浏览器的二次开发来会举例讲解下指纹浏览器的原理,以及具体改写的步骤,但是不会涉及太深的内容。因为chromium这个开源项目现在非常庞杂,不建议每个人都去尝试进行二次开发,花钱买个成熟产品即可,没必要所有东西都自己写。
  Q2 Z9 F( N3 v9 E0 _4 N9 echromium的二次开发说难也难,因为它涉及到的编程语言就有C、C++、Java、Python、Javascript这么多种,但是说简单也,它也简单,因为改写指纹浏览器只需要你会C++就够了。9 ~: j- v" x. i" R+ D
本人也不提供任何形式的关于本文问题的解答,毕竟准备工作的第一步就跟大环境冲突,还不想给自己找麻烦。
2 s# R8 ^2 O9 i4 q- t# y1 t/ v( j文章以Linux系统Ubuntu举例,为什么不以Windows系统是因为Windows下的指纹浏览器产品太多了,根本没必要写,买就完了。
4 o' F% k$ l' Q) }8 T文章会同时发布到多个平台,如果里面的代码部分略有错乱,建议还是去sanfenzui.com博客进行查看,因为博客是支持markdown的,对代码的支持更好一些。0 w' P0 D+ u- A) Y
如果你要编译chromium85以下的版本,一定要用Ubuntu18及以下,Ubuntu20是无法编译老版本的chromium的,而太新版本的chromium可能最低就需要Ubuntu20,这个看你要编译的chromium版本。$ c$ B/ w) h( Z) _
编译环境为Ubuntu20,编译版本为chromium最新版,非限定特定版本。

Ubuntu下chromium浏览器编译
  • 首先要做准备工作,构建全局上网不受限的环境,由于chromium源码地址是谷歌的,想要clone下来需要自备全局上网不受限的环境。
  • 拉取depot_tools工具git clone https://chromium.googlesource.com/chromium/tools/depot_tools.git" [0 T# d1 F  `7 ^3 o& k
    然后在当前用户的根目录下,打开vim ~/.bashrc 并将depot_tools的bin目录放到path下。也就是写入$ A. y* t5 D( w' _& y
    1. export PATH="$PATH:${HOME}/depot_tools"
    复制代码
    然后回到目录中,执行
    2 ]  ~9 ?8 p1 B/ B, y$ N0 Ksource ~/.bashrc% Y+ z' S/ E2 e& v4 _* L  ~& w* j
    使配置生效。
  • 获取源码
    - t$ M/ A2 ~! c在当前用户的根目录下(最好别用root用户)创建一个你放源码的文件$ E" N( ?/ E$ ?1 j9 ~
    mkdir ~/chromium && cd ~/chromium
    # Q0 D$ b, e- p8 p" P6 E然后用fetch工具来获取源码,fetch工具是depot_tools中的工具& y& B/ _3 Q9 h2 i" T
    fetch --nohooks --no-history chromium
    6 m$ i" Q8 v) ~0 E# J此处可以看到有参数--no-history它的作用就是不下载老版本的chromium源码(非常非常多的文件,实在是受不了),只下载最新版的,如果你需要编译老版本的chromium,一定不要添加这个。$ P6 g' z7 V8 m/ i3 U+ z- b  C1 R
    如果提示fetch不存在,那么只有可能你的depot_tools没有下载成功或者没有加入到系统path中。; @- B( {! H* ]% U2 ^
    这里需要注意的是,该命令因你所处的网络环境,可能会长达数小时。所以获取源码的时候一定要找一个网络环境比较好且稳定的情况下进行,晚上睡觉的时候下载是一个不错的办法。) A5 N* x  {3 H
    如果fetch失败可以运行gclient sync继续进行同步。
  • 下载依赖( F, M& C$ B  f& u) I3 x, T+ a
    我们下载下来的源码中,有个src目录,进去之后执行6 b& t  o/ M2 y) X1 \$ L
    ./build/install-build-deps.sh
    0 x6 b8 O$ J( N0 t6 _如果该命令没有下载大量的(接近1.5G)包,且出现了
    . \0 _4 D4 p: E8 X8 uE: Could not configure 'libc6:i386'.E: Could not perform immediate configuration on 'libgcc-s1:i386'. Please see man 5 apt.conf under APT::Immediate-Configure for details. (2)

    这样的错误,这个问题可以归咎于ubuntu20.04系统的问题,你需要首先先执行9 O* ^8 x6 X8 n. \
    apt-get dist-upgrade -o APT::Immediate-Configure=0
    9 n# }8 ?1 T/ ]. H9 }然后再执行一遍下载依赖的./build/install-build-deps.sh脚本即可。! Z( m! P1 S! @$ c- |5 W0 o" I9 |
    等到依赖安装完毕,就可以看源码了。+ l6 Z7 Z/ y/ ]" m
    chromium源码结构
    ( {: ~6 n3 {" P* I( a. }. U$ E4 n, L7 T
    chromium下载下来的代码非常巨大,但是大部分都是测试代码。相关的资料,去官网看开发者文档就行。" X6 G' d& A5 z9 l
    linux平台编译官方文档:
    ! J( F- o3 b6 j. V7 I; Ehttps://chromium.googlesource.com/chromium/src/+/master/docs/linux/build_instructions.md
    . |* {, N' A! Y6 C* C, X9 X6 _- |控制浏览器行为的代码一般是在blink相关的目录下。我就是对blink下的源码进行了修改,定义了符合自己应用场景的函数。
    ! o  @, {3 u4 q( N具体更改哪些位置在本篇文章下面,让我们继续编译浏览器。

  • 编译chromium, |2 T0 X% b  P  f8 }* p: ]
    首先执行
    9 i: A+ ?  F, }' J6 }6 [& I$ ygclient runhooks; N8 G. E; H; W% ?! c1 ]5 b& f
    如果提示gclient config not found就运行gclient config https://chromium.googlesource.com/chromium/src.git1 m" T) t+ Y2 _/ I
    下载hook并执行,完成之后,执行下面的命令即可4 J, c. a( C4 t% f# O# l2 r! U
    gn gen out/Default# 这一步大概等待10s-60s左右autoninja -C out/Default chrome

    运行后就开始初次编译了,这一步大约需要十个小时,主要跟电脑的配置有关,一定要ssd硬盘(100G以上剩余空间),内存最低16GB以上,cpu频率越高越好、核心数越多越好。
    4 @" Y# b0 M! C2 u* J: |不要被这个时间吓到了,当你更改源码后再次编译很快就编译完成了,因为它只是把你新改的部分进行重新编译,这样时间就节省非常多了。
    1 ?( n: K. Z6 T$ A1 v后来我租用了一个高配服务器,服务器配置记得是双cpu、256G内存、2Tssd,这回就快很多了,首次编译也只用了半个多小时就编译完成了,。
    : C+ x+ S) B& ?- C" {. o# _, D. Y) V* J. D; S* S+ C: `; }. k- x( b5 V
    可以看到cpu几乎占满了,编译完成之后,进入到out/Default目录即可看见名为chrome的可执行文件。

    ' Z6 V% }" k, u3 g0 v: R

    ' g7 d2 U; W  b& M2 C$ j
指纹浏览器编写, J' a2 U9 Y# r4 U' J+ f. U

根据系列教程第三篇文章,一大堆在线检测站的测试,我们发现,大部分指纹检测站都是检测浏览器的以下信息:

  • Useragent
  • cpu核心
  • 内存大小
  • 屏幕大小
  • 浏览器语言
  • 色深
  • WebGL
  • Vendor
  • Canvas
  • Audio
  • Fonts
  • Timezone
    6 B3 O  V2 L( q6 W. F2 \0 O4 ]其中Useragent和Timezone都可以通过浏览器命令行参数来指定,我认为就没必要修改浏览器了,当然有些人为了参数设置的统一性,也有改源码的。0 {9 }" I  n3 ^& _- Q. R
    下面我们以浏览器的WebGL Vendor和WebGL Renderer硬件信息举例如何修改。# {" E( }3 S4 g/ V# N
    0 Y/ G1 M0 R# F8 Q
    我们要更改的chromium源码文件位置在src/third_party/blink/renderer/modules/webgl/webgl_rendering_context_base.cc,要更改的文件在modules下面的webgl文件夹里。
    . h1 m% @; U; a4 Q4 e: e; x可以看到这两个函数会返回webgl的相关信息,那么我们只要改变这两个变量的返回值,就可以起到伪造webgl指纹信息的效果了。
    1 ]* M, e/ k+ u; p此处我将返回值改为图中的固定值,重新编译后,打开浏览器,我们通过浏览器指纹在线检测:https://bot.sannysoft.com/ 进行检测。
    : q2 f3 n1 e- F9 g0 t& z0 _4 I' S结果如下图:( {# A' ^) z' N
    4 p4 ^+ i9 x% g* z/ \( ^: n1 y
    在前面讲解测试的时候我们知道webgl处显示的是用户的显卡信息,现在可以看到浏览器指纹里的webgl这两项,已经成功变为我在程序里指定的值了,那么如果你想要自己弄浏览器指纹,只要通过传递参数到这个值所在位置就可以起到更改浏览器显卡信息的效果了。7 [, W- i2 y6 Y  E( L

    6 I9 D, O* n& Y1 o+ ^, g  Q7 }
指纹信息参数传递的方法6 d9 s! X3 ^5 _: u  e7 h; \) [

如何传递参数过来,不同的指纹浏览器的方法也不同,这里列出大部分指纹浏览器的解决方案。

  • 直接调用MySQL等数据库里的指纹信息( h! N/ d# K4 n8 N! v" K& H  h
    这种方式的好处是自己用非常方便,坏处就是如果给其他客户使用会容易被人拖库。
  • 通过浏览器参数进行传递# k2 t- x1 h% w% E; O
    就是类似前面我们将浏览器多开里的参数传递,很多主流的指纹浏览器都是这种形式的,好处是只要增加浏览器源码里参数传递的接收部分,就可以非常轻松做到可用状态。坏处是浏览器启动命令非常的长,还涉及命令行启动传递参数里编码转换问题,不过这些都不算大问题,也是很多浏览器的传参方式。
  • 浏览器内部增加api接口  D' x. w& U2 d5 v8 D2 t
    这种凡是跟第一种调用MySQL数据库的方式类似,都是调用数据库里的,只是这里多了一步,增加API接口让浏览器后台可以跟浏览器服务商的服务器进行通信,好处是可以实现随时验证是否被破解、实时加载、cookie同步等功能。坏处就是需要给浏览器增加更多的功能,因为chromium这个开源项目跟老太太裹脚布一样,又臭又长,尤其阿三参与后,现在想增加一个功能,都需要更改非常非常多的相关代码,而这样做的后果是,稍微不注意,编译的浏览器就崩溃了。
  • 增加启动器调用浏览器
      Q5 b/ r8 F7 T& I5 N7 Q2 o9 o: g3 |3 U这种是大部分指纹浏览器的使用方式,写一个客户端多开器,调用自己改写的指纹浏览器,这个客户端负责跟服务器进行通信,之后传递指纹信息和cookie等给浏览器。而传递的形式可以是第二种,也可以是第三种,还有一种是通过客户端让浏览器加载一个用于通信的浏览器插件,浏览器通过这个插件同多开器进行通信从而传递参数。% a' A0 v% G. K7 _/ G7 _( ^

    5 ]$ L. r1 k" E( b7 V0 s8 N
更多硬件信息源码位置. _9 `  t; g7 K% E& J: K
  1. <font color="#000000" data-darkreader-inline-color="" style="--darkreader-inline-color:#ece8e2;">处理器核心数量:src/third_party/blink/renderer/core/frame/navigator_concurrent_hardware.cc
    " c/ Z5 l, [" w( ^) \$ k
  2. Useragent、系统类型:src/chrome/browser/chrome_content_browser_client.cc
    + A) O, k; `0 v6 F" K
  3. Canvas:src/third_party/blink/renderer/modules/canvas/canvas2d/base_rendering_context_2d.cc
    ; u! ]# _. M( B* a; f* |
  4. Audio:src/third_party/blink/renderer/modules/webaudio/base_audio_context.cc
    3 e. L( H& R2 {1 V% M
  5. Fonts:src/third_party/blink/renderer/platform/fonts! z2 T, R/ w' o
  6. 内存大小:src/third_party/blink/renderer/core/frame/navigator_device_memory.cc
    $ V( {: L# ^7 y& w/ j
  7. 系统平台:src/third_party/blink/renderer/core/frame/navigator_id.cc  C( i% m) I  i+ i
  8. 屏幕大小,色深:src/third_party/blink/renderer/core/frame/screen.cc</font>
复制代码
/ }) q# w: ~! I, Y( r. |$ n

# g! F* i1 _3 B% P3 wBrave浏览器

为什么我总提到它呢,就是因为它自身就是标榜block fingerprint的,它自身就有通过命令行可以设置是否禁止webgl等指纹信息的功能,非常适合指纹浏览器的改写。! f" x  z3 a8 {+ Q* s
- d! ^, @3 H0 k& e! t& ^& A
在设置页面里也可以看到关于拦截指纹的选项,地址brave://settings/shields。
" u% t; B5 ?+ G' o% A4 j' l5 `+ H* e$ o
开源地址:https://github.com/brave/brave-browser
5 C) y) z& ~9 o7 m它是通过node.js脚本把chromium编译过程给简化了,所以先要安装node.js和npm,这里大家按文档要求进行安装即可。8 e( v, Z/ n2 A9 s, ~
按照它的README.md里的编译步骤走就行,比原版chromium方便的不要太多。我这里就不写具体的步骤了,只是分享下遇到的问题和注意事项。

  • 要提前保证python可用,命令行python这种,而不是默认的python3,想要切换python3为默认的python,就输入命令alias python=python3
  • brave依然会去chromium官方拉取源码,所以一个稳定的网络环境依然是需要的。
  • 提前安装gcc,apt install gcc
  • 提前更新opensslapt-get updateapt-get install musl-tools -yapt-get -y install pkg-config libssl-devCOPY

    Brave浏览器是也是开源跨平台的浏览器,大家根据自己的喜好进行编译即可,Brave官方精简后的脚本非常易用。

    6 x- c  \' ?, B
    # G( b# n$ w+ E! ]9 B  s
指纹数据的来源

很多刚接触这个的朋友会想,如果我改写的浏览器,现在测试阶段要多个浏览器实例,那指纹不能都一样啊,涉及那么多变量,去哪里弄呢?# @4 K7 S6 P/ Y+ }
这里抛砖引玉两个方向,有更好的方案,欢迎补充:

方向一:使用市面上成熟指纹浏览器产品的指纹参数

前期当自己没有指纹浏览器那么多可变的参数的时候,而自己改写的浏览器又需要这些来做测试,那么可以先借鉴市面上已经成熟指纹浏览器产品的指纹数据。至于如何借鉴,相信各位心中有数,这里就不展开讲了。

方向二:自建在线指纹检测网站

大家可以看到一个现象,大部分指纹浏览器的开发商都配套有个自家的在线指纹检测的网站,有些即使不是明确说是自己的,也大概率是他们自己开发的。' H" K9 q, S$ p6 i
当你使用它去进行检测浏览器指纹的时候,你的指纹所有信息都会筛选后进入它的数据库,即使你都是用他家的自身的,会有重复,那还有其他人也在用这个检测网站进行检测指纹,把重复数据筛选下,剩下的就是源源不断的新设备的指纹了,只要把这些再入库,将他们再次排列组合,指纹浏览器就会得到更多、更新的指纹信息。/ }: u" d9 v. ?4 B3 e5 D
所以我们也可以模仿这种形式,自建一个在线指纹检测的工具站,既能获得新的设备指纹信息,又成功养起来一个工具站。* R0 C( O! ]3 L0 |/ A& u
想要工具站源码的朋友可以添加我的微信公众号,搜索名字"三分醉出海",或搜索全拼“sanfenzuichuhai”也能搜到,回复“工具站”三个字就可以下载它了。。
8 ?& i3 M) U( C5 }# B


1 r; T* A' L; h: v2 \个人定制

更改chromium的名字为自己定义的,对应的文件为src/chrome/app/chromium_strings.grd# B2 u4 {) p3 I' e8 B/ j0 W
批量替换了里面chromium为SanfenzuiBrowser
0 q2 S& e) C/ j: Z2 ]并且所有文件里替换Chromium is made possible by为SanFenZuiBrowser is made possible by
. n/ n& A+ v& L1 `1 ?4 i! `' Z更改Google Chrome is made possible by为SanFenZui Browser is made possible by
2 i# Y& Y2 C# b8 M1 G9 o# \, `/ D替换[tr]Chromium 为[tr]SanFenZuiBrowser( B: H: Y  S7 h2 _( g* \
再次编译后打开网址chrome://settings/help或点击浏览器右上角下拉里的关于按钮,效果如下图:
  P# N: b2 N- r' l4 Y
+ m* X% U9 m# j& v$ w最后再替换下src/chrome/app/theme/文件夹里面的浏览器图标,对编译成功的浏览器程序再打个包,你就可以对宣传了,《自主研发、独立研发国产浏览器》,手动狗头:)

本篇文章基本上写全了指纹浏览器的核心内容,如果对你有所帮助,希望在公众号对本文打赏,我会更有动力写出更多的文章,感谢支持!

本文由三分醉博客原创,转载请注明:https://www.sanfenzui.com/write-your-own-fingerprint-browser-and-the-source-of-fingerprint-information.html

文章同步更新在知乎:三分醉 - 知乎

4 e5 U( e4 T9 [0 V$ n, E1 J1 v

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x

评分

参与人数 3广告币 +60 收起 理由
alibaba + 30 很给力!
lailailai + 20 很给力!
blackhat + 10 很给力!

查看全部评分

相关帖子
个人博客:SanFenZui.com 公众号:三分醉出海
回复

使用道具 举报

1

主题

11

广告币

37

积分

初级会员

Rank: 2

积分
37
发表于 2022-4-8 23:34:04 | 显示全部楼层
回复 支持 反对

使用道具 举报

69

主题

8687

广告币

8557

积分

版主

Rank: 7Rank: 7Rank: 7

积分
8557

社区QQ达人

发表于 2022-4-9 10:13:57 | 显示全部楼层
不错不错 感谢分享
回复 支持 反对

使用道具 举报

77

主题

1039

广告币

2077

积分

高级会员

Rank: 4

积分
2077

社区QQ达人

发表于 2022-4-10 16:04:53 | 显示全部楼层
不过 可以学习一下
备份
911替换
IPRoyal
处女级IP
ProxySites.ai✅           ProxySeller.com✅
回复 支持 反对

使用道具 举报

26

主题

1060

广告币

2683

积分

高级会员

Rank: 4

积分
2683
发表于 2022-4-12 12:01:34 | 显示全部楼层
大佬nb
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关于我们|联系我们|DMCA|广告服务|小黑屋|手机版|Archiver|Github|网站地图|AdvertCN

GMT+8, 2025-8-25 20:10 , Processed in 0.053169 second(s), 15 queries , Gzip On, MemCache On.

Copyright © 2001-2023, AdvertCN

Proudly Operating in Hong Kong.

快速回复 返回顶部 返回列表