怎么检测Edge浏览器中已安装的扩展应用


一、前言


对攻击者来说,如果能够收集受害者的指纹信息是最好不过的事情。在前面的文章中,我们已经知道攻击者可以利用漏洞来检测特定文件的存在(以规避安全分析人员的检测),也可以将mimeTypes与应用程序相关联。微软及时修复了这两个漏洞,也封堵了与之相关的其他漏洞。今天,我们将向读者展示如何检测Edge浏览器中已安装的扩展应用。

4月5日,Nataliia Bielova发布了一条推文,介绍了某个网站如何检测多个浏览器上已安装的扩展应用,但微软的Edge并不包括在内。

如果读者希望进一步了解如何检测Firefox和Chrome浏览器的扩展应用,可以参考这篇文章以获取更多知识。本文我们将在Edge浏览器上完成同样任务。

二、安装扩展


在Edge浏览器的扩展商店中,我随机选择一款名为AdGuard blocker的扩展应用。两次鼠标点击后,扩展已安装完毕,自动打开了一个感谢页面。正是这个页面给了我研究的灵感,如下图所示:

我们可以利用上面的URL信息开始研究。如果我们能够在一个iframe内部中加载该URL,通过onload或onreadystatechange事件(或者其他事件),判断获取的是Edge浏览器的标准404页面(即扩展未安装)还是该扩展的thankyou.html页面,那么我们基本上就可以判断该扩展是否存在。不幸的是,iframe拒绝加载该扩展的URL。

1

   

如果使用windows.open方法,结果如何呢?我们可以尝试在脚本中打开扩展的URL:

1. 2

win = window.open("ms-browser-extension://EdgeExtension_AdguardAdguardAdBlocker_m055xr0c82818/pages/thankyou.html");    
// win returns null when the URL is ms-browser-extension    

页面打开成功!不过对我们来说这个结果用处不大,因为不管扩展是否安装,windows对象返回值始终为空(null)。换句话说,当我们试图使用ms-browser-extension扩展协议打开一个新建窗口时,返回结果始终为null。因此即使我们的确能够打开浏览器窗口(当然这是个丑陋的解决方案),我们也无法判断获取的结果是否准确。

我们是否可以利用扩展中的图片来判断呢?扩展中的图片有可能会暴露在主页面中,我们可以使用onload或onerror事件检测扩展是否安装。首先,我们需要找出扩展文件存放在文件系统中具体位置。

三、定位扩展文件


运行Process Monitor,将MicrosoftEdgeCP.exe添加到过滤规则中。打开Edge浏览器,在地址栏中输入AdGuard扩展的URL,载入扩展的感谢页面。在Process Monitor中,我们很快就可以定位到扩展文件所处的具体位置。记住我们的目标是找出扩展中的图片,判断是否可以通过onload或onerror事件检测图片的存在。

看起来扩展文件存放在如下位置:

访问上一层目录,我们可以看到其中存在一个manifest.json文件,定义了某些资源可以被任何网站加载,与Chrome或Firefox浏览器类似。

这些资源大多数都是图片资源,我们可以尝试使用下面这个脚本加载logo.svg图片,如果触发onload事件,则表明该扩展已安装,否则表明用户并没有安装该扩展。

这种方法并没有让我眼前一亮,因为我们还是重复以前检测的老套路(与Chrome和FireFox浏览器上的方法类似),我们过度依赖于扩展的积极配合,允许我们加载其内部资源。如果某个扩展在manifest文件中不存在Web可以访问的资源,这种情况下我们如何检测它的存在呢?

四、检测扩展的通用方法


经过了短暂的尝试后,我决定借鉴Soroush提出的IE DTD技巧,这类技巧尝试使用微软的XMLDOM对象加载资源,通过错误号来判断资源文件的存在与否。在Edge浏览器上,我们没有XMLDOM对象,但我们可以使用与之类似的XMLHttpRequest对象。

使用XMLHttpRequest对象打开资源时,如果扩展存在,它会抛出拒绝访问异常,否则会抛出未指定错误异常。为了表示对Soroush成果的尊重,我们同样采用异常错误号来判断所抛出的异常类别。代码如下所示:

结果非常不错,感谢Soroush的伟大发现。

顺便提一下,你是否注意到我们使用的URL并没有指向任何一个资源文件?这涉及到XML的一些技巧。对XML来说,使用目录名就已足够,我们不需要指向某个特定资源,只需要掌握扩展的ID信息就足以检测扩展是否存在。如果我们希望实现一个通用的检测工具,查找所有的扩展信息,我们首先需要在自己的Edge浏览器上安装所有的扩展,记录这些扩展的ID。我们只需要在安装扩展后,打开一个空白页面,按下F12,就可以找到扩展的ID信息。如下图所示:

我们现在可以利用这些信息为Edge浏览器创建一个通用的扩展检测工具。已禁用的扩展不会在开发者工具中加载,但我们还是可以在注册表中找到它们。

即使用户禁用了扩展,我们的检测方法仍然行之有效。我们利用PoC检测出来的20个已安装的扩展信息,如下图所示。

检测已安装扩展的PoC可以在这里找到。

(0)

相关推荐

  • 在Microsoft Edge浏览器中怎么安装扩展插件

    我们想要给电脑上的edge浏览器提高性能,就要给浏览器安装一些扩展插件,今天就跟大家介绍一下在Microsoft Edge浏览器中怎么安装扩展插件的具体操作步骤.1. 首先打开电脑上的edge浏览器2 ...

  • 如何清除edge浏览器中已保存的表单数据

    我们使用的edge浏览器,默认保存表单数据,想要进行清除,该怎么操作呢?今天就跟大家介绍一下如何清除edge浏览器中已保存的表单数据的具体操作步骤.1. 首先打开电脑,找到桌面上的edge浏览器图标, ...

  • 怎么在Edge浏览器中设置阻止已关闭的网站接收或发送数据

    现在很多人都在使用edge浏览器进行浏览网页,今天就跟大家介绍一下怎么在Edge浏览器中设置阻止已关闭的网站接收或发送数据的具体操作步骤.1. 首先打开电脑上的Edge浏览器,进入主页面后,点击页面右 ...

  • 如何在Edge浏览器中安装AdBlock扩展程序

    现在有很多人喜欢在电脑上使用Edge浏览器上网,有些新用户不知道如何安装AdBlock扩展程序,接下来小编就给大家介绍一下具体的操作步骤.具体如下:1. 首先第一步先打开电脑中的Edge浏览器,接着根 ...

  • 如何卸载新版Edge浏览器中的插件

    如何卸载新版Edge浏览器中的插件呢?一起来看看具体操作步骤吧.1. 首先打开电脑,找到桌面上的Edge浏览器图标,双击打开.2. 进入主页面后,点击右上角的[•••]图标.3. 在打开的菜单中,选择 ...

  • win10系统edge浏览器插件怎么安装

    win10 edge浏览器插件怎么安装?用户在使用Win10正式版系统的时候,是否了解这样一个问题,就是系统中的Edge浏览器是不支持扩展插件的,不过还好最新的预览版中,微软终于给Edge浏览器增加了 ...

  • chrome浏览器怎么导出已安装的扩展程序(插件)为crx文件?

    我们都知道,如今Chrome浏览器的应用商店都打不开,进不去了,需要翻出去才能上.所以对于一些已经安装过的扩展程序(插件)想导出保存一下.因为Chrome默认安装在C盘,怕重装系统后又要重新安装这些插 ...

  • 一招教你解决win7中已安装的程序的兼容性问题

    相信很多小伙伴都有在使用windows系统,那么在其中我们怎么去解决已安装的程序的兼容性问题呢?方法很简单,下面小编就来为大家介绍.具体如下:1. 首先,打开电脑桌面左下角的开始菜单,在弹出选项中点击 ...

  • 如何关闭edge浏览器中显示的360主页锁定

    我们新安装的edge浏览器,打开后发现主页是360的主页,并锁定了,该怎么关闭呢?今天就跟大家介绍一下如何关闭edge浏览器中显示的360主页锁定的具体操作步骤.1. 首先打开电脑,找到桌面上的edg ...

  • 如何在新版Edge浏览器中添加扩展

    今天给大家介绍一下如何在新版Edge浏览器中添加扩展的具体操作步骤.1. 首先打开电脑,找到桌面上的Edge浏览器图标,双击打开2. 进入主页面后,点击右上角的[• • •]图标3. 在打开的菜单中, ...