网易首页 > 网易号 > 正文 申请入驻

私有数据、删掉的内容可以永久访问,GitHub官方:故意设计的

0
分享至

选自trufflesecurity.com

机器之心编译

机器之心编辑部

最近,一个消息震惊开源社区:在 GitHub 上删掉的内容、私有存储库的数据都是可以永久访问的,而且这是官方故意设计的。

开源安全软件公司 Truffle Security 在一篇博客中详细描述了这个问题。

Truffle Security 引入了一个新术语:CFOR(Cross Fork Object Reference):当一个存储库 fork 可以访问另一个 fork 中的敏感数据(包括来自私有和已删除 fork 的数据)时,就会出现 CFOR 漏洞。

与不安全的直接对象引用类似,在 CFOR 中,用户提供提交(commit)哈希值就可以直接访问提交数据,否则这些数据是不可见的。

以下是 Truffle Security 博客原文内容。

访问已删除 fork 存储库的数据

想象如下工作流程:

  • 在 GitHub 上 fork 一个公共存储库;
  • 将代码提交到你的 fork 存储库中;
  • 你删除你的 fork 存储库。

那么,你提交给 fork 的代码应该是不能访问了对吧,因为你把 fork 存储库删除了。然而它却永久可以访问,不受你控制。

如下视频所示,fork 一个存储库,向其中提交数据,再删除 fork 存储库,那么可以通过原始存储库访问「已删除」的提交数据。

这种情况普遍存在。Truffle Security 调查了一家大型 AI 公司 3 个经常被 fork 的公共存储库,并从已删除的 fork 存储库中轻松找到了 40 个有效的 API 密钥。

访问已删除存储库的数据

考虑如下工作流程:

  • 你在 GitHub 上有一个公共存储库;
  • 用户 fork 你的存储库;
  • 你在他们 fork 后提交数据,并且他们从不将其 fork 存储库与你的更新同步;
  • 你删除整个存储库。

那么,用户 fork 你的存储库后你提交的代码仍然可以访问。

GitHub 将存储库和 fork 存储库储存在存储库网络中,原始「上游」存储库充当根节点。当已 fork 的公共「上游」存储库被「删除」时,GitHub 会将根节点角色重新分配给下游 fork 存储库之一。但是,来自「上游」存储库的所有提交仍然存在,并且可以通过任何 fork 存储库访问。

这种情况不是个例,上周就发生了这样一件事情:

Truffle Security 向一家大型科技公司提交了一个 P1 漏洞,显示他们意外地提交了一名员工 GitHub 帐户的密钥,而该帐户对整个 GitHub 机构拥有重要访问权限。该公司立即删除了存储库,但由于该存储库已被 fork,因此仍然可以通过 fork 存储库访问包含敏感数据的提交,尽管 fork 存储库从未与原始「上游」存储库同步。

也就是说,只要存储库有至少一个 fork 存储库,那么提交到公共存储库的任何代码都可以永久访问。

访问私有存储库数据

考虑如下工作流程:

  • 你创建一个最终将公开的私有存储库;
  • 创建该存储库的私有内部版本(通过 fork),并为不打算公开的特征提交额外的代码;
  • 你将你的「上游」存储库公开,并将你的 fork 存储库保持私有。

那么,私有特征和相关代码则可供公众查看。从你创建工具的内部 fork 存储库到开源该工具之间提交的任何代码,这些提交都可以通过公共存储库访问。

在你将「上游」存储库公开后,对你的私有 fork 存储库所做的任何提交都是不可见的。这是因为更改私有「上游」存储库的可见性会导致两个存储库网络:一个用于私有版本,一个用于公开版本。

不幸的是,该工作流程是用户和机构开发开源软件时最常用的方法之一。因此,机密数据可能会无意中暴露在 GitHub 公共存储库上。

如何访问数据?

GitHub 存储库网络中的破坏性操作(如上述 3 个场景)会从标准 GitHub UI 和正常 git 操作中删除提交数据的引用。但是,这些数据仍然存在并且可以访问(commit hash)。这是 CFOR 和 IDOR 漏洞之间的联系。

commit hash 可以通过 GitHub 的 UI 进行暴力破解,特别是因为 git 协议允许在引用提交时使用短 SHA-1 值。短 SHA-1 值是避免与另一个 commit hash 发生冲突所需的最小字符数,绝对最小值为 4。所有 4 个字符 SHA-1 值的密钥空间为 65536 (16^4)。暴力破解所有可能的值可以相对容易地实现。

有趣的是,GitHub 公开了一个公共事件 API 端点。你还可以在由第三方管理的事件存档中查询 commit hash,并将过去十年的所有 GitHub 事件保存在 GitHub 之外,即使在存储库被删除之后也是如此。

GitHub 的规定

Truffle Security 通过 GitHub 的 VDP 计划将其发现提交给了 GitHub 官方。GitHub 回应道:「这是故意设计的」,并附上了说明文档。

说明文档:https://docs.github.com/en/pull-requests/collaborating-with-pull-requests/working-with-forks/what-happens-to-forks-when-a-repository-is-deleted-or-changes-visibility

Truffle Security 赞赏 GitHub 对其架构保持透明,但 Truffle Security 认为:普通用户将私有和公共存储库的分离视为安全边界,并且认为公共用户无法访问私有存储库中的任何数据。不幸的是,如上所述,情况并不总是如此。

Truffle Security 得出的结论是:只要一个 fork 存储库存在,对该存储库网络的任何提交(即「上游」存储库或「下游」fork 存储库上的提交)都将永久存在。

Truffle Security 还提出一种观点:安全修复公共 GitHub 存储库上泄露密钥的唯一方法是通过密钥轮换。

GitHub 的存储库架构存在这些设计缺陷。不幸的是,绝大多数 GitHub 用户永远不会理解存储库网络的实际工作原理,并且会因此而降低安全性。

原文链接:https://trufflesecurity.com/blog/anyone-can-access-deleted-and-private-repo-data-github返回搜狐,查看更多

特别声明:以上内容(如有图片或视频亦包括在内)为自媒体平台“网易号”用户上传并发布,本平台仅提供信息存储服务。

Notice: The content above (including the pictures and videos if any) is uploaded and posted by a user of NetEase Hao, which is a social media platform and only provides information storage services.

相关推荐
热点推荐
中东局势一夜突变:五万美军紧急刹车,内塔尼亚胡陷入绝境

中东局势一夜突变:五万美军紧急刹车,内塔尼亚胡陷入绝境

民间胡扯老哥
2026-04-04 21:20:45
1950 年川农妇报案,劈柴丈夫竟是失踪国军中将王凌云

1950 年川农妇报案,劈柴丈夫竟是失踪国军中将王凌云

唠叨说历史
2026-01-21 16:28:08
球童:多纳鲁马把纸条藏毛巾里,我一心想帮波黑就把它拿走了

球童:多纳鲁马把纸条藏毛巾里,我一心想帮波黑就把它拿走了

懂球帝
2026-04-06 07:15:07
分手29年后,肖战成国乒副总教练,而她嫁给富商,已是大学教授

分手29年后,肖战成国乒副总教练,而她嫁给富商,已是大学教授

做一个合格的吃瓜群众
2026-04-06 10:16:48
61岁港星清明回乡祭祖!蹲泥地徒手啃烤猪,吃得满嘴油光,接地气

61岁港星清明回乡祭祖!蹲泥地徒手啃烤猪,吃得满嘴油光,接地气

小娱乐悠悠
2026-04-06 08:40:19
别再白跑冤枉路!身份证到期换证,只需要改这一处,很多人做错

别再白跑冤枉路!身份证到期换证,只需要改这一处,很多人做错

复转这些年
2026-04-04 07:47:46
陈光标晒图:张雪迟迟未来提车,特此将车辆变现资金捐赠给嫣然医院;此前张雪称会将其赠送的1300万劳斯莱斯卖掉,把钱捐给嫣然天使基金

陈光标晒图:张雪迟迟未来提车,特此将车辆变现资金捐赠给嫣然医院;此前张雪称会将其赠送的1300万劳斯莱斯卖掉,把钱捐给嫣然天使基金

潇湘晨报
2026-04-05 16:45:15
火箭险胜勇士,乌杜卡引众怒!赛后一览谁是最大功臣,不是杜兰特

火箭险胜勇士,乌杜卡引众怒!赛后一览谁是最大功臣,不是杜兰特

徐觳解说
2026-04-06 13:02:26
马克龙答应高市,G7峰会没中国,2天之后,在韩国又摆中方一道

马克龙答应高市,G7峰会没中国,2天之后,在韩国又摆中方一道

天启大世界
2026-04-06 13:17:33
绿营瑟瑟发抖?拼连任的蒋万安最新民调出炉,比上次还高4.4%

绿营瑟瑟发抖?拼连任的蒋万安最新民调出炉,比上次还高4.4%

海峡导报社
2026-04-06 10:57:02
米切尔38+6+6!骑士逆转横扫步行者 哈登28+7一壮举联盟第一

米切尔38+6+6!骑士逆转横扫步行者 哈登28+7一壮举联盟第一

醉卧浮生
2026-04-06 08:22:50
身体这处毛发变白,暗示活得不长?看看你白了没有

身体这处毛发变白,暗示活得不长?看看你白了没有

白话电影院
2026-04-05 22:42:04
全程眼突鼓腮,看了观众对孙俪的评价,才知张艺谋这句话的含金量

全程眼突鼓腮,看了观众对孙俪的评价,才知张艺谋这句话的含金量

陈述影视
2026-04-04 17:53:34
哈兰德戴帽后拿走比赛用球,队友球上留言:干得好,你这该死的怪胎

哈兰德戴帽后拿走比赛用球,队友球上留言:干得好,你这该死的怪胎

懂球帝
2026-04-06 11:22:10
这是毛岸青和妻子第一次给妈妈扫墓4张合照,刘思齐陪同

这是毛岸青和妻子第一次给妈妈扫墓4张合照,刘思齐陪同

海佑讲史
2026-03-20 10:40:10
周杰伦杭州演唱会被指划水,3小时演唱会实唱不足90分钟?现场观看粉丝:氛围很嗨,他一直在唱

周杰伦杭州演唱会被指划水,3小时演唱会实唱不足90分钟?现场观看粉丝:氛围很嗨,他一直在唱

极目新闻
2026-04-06 11:44:07
陈光标没有骗张雪,将豪车变现给嫣然天使捐款1000万,晒出汇款单

陈光标没有骗张雪,将豪车变现给嫣然天使捐款1000万,晒出汇款单

叨唠
2026-04-05 18:44:14
太委屈!女子清明回娘家偷偷给母亲3000被公开,兄弟姐妹轮番指责

太委屈!女子清明回娘家偷偷给母亲3000被公开,兄弟姐妹轮番指责

火山詩话
2026-04-06 07:51:26
世锦赛下午六点开锣!赵心童是1号种子,和丁俊晖、肖国栋同区!

世锦赛下午六点开锣!赵心童是1号种子,和丁俊晖、肖国栋同区!

格斗社
2026-04-06 10:17:50
老了才明白:永远不要在儿女面前,表现出这几种行为,才会幸福

老了才明白:永远不要在儿女面前,表现出这几种行为,才会幸福

阿凯销售场
2026-04-06 14:08:43
2026-04-06 14:35:00
机器之心Pro incentive-icons
机器之心Pro
专业的人工智能媒体
12681文章数 142614关注度
往期回顾 全部

科技要闻

前同事被蒸馏成Token,AI能否偷走职场经验

头条要闻

牛弹琴:特朗普两个举动很反常 美国上下都很震惊

头条要闻

牛弹琴:特朗普两个举动很反常 美国上下都很震惊

体育要闻

球员系列赛大满贯!赵心童10-3世界第一 加冕赛季第4冠

娱乐要闻

乔任梁离世10年 父母曝舞台光鲜的背后

财经要闻

118吨!这家央行,大幅抛售黄金!

汽车要闻

家用SUV没驾驶乐趣?极氪8X第一个不同意

态度原创

教育
旅游
时尚
亲子
家居

教育要闻

让孩子远离手机的10个方法(建议收藏)

旅游要闻

江西南昌:清明踏青正当时

AI时代,辨别真相的成本变高了

亲子要闻

一定要让孩子刻在脑子里

家居要闻

温馨多元 爱的具象化

无障碍浏览 进入关怀版