站长网 安全 APACHE OFBIZ XMLRPC远程代码执行漏洞详解

APACHE OFBIZ XMLRPC远程代码执行漏洞详解

副标题#e# 漏洞分析 Apache OFBiz是一个开源的企业资源规划(ERP)系统,它提供了一系列企业应用程序来帮助企业自动化实现很多业务流程。它包含了一个能提供常见数据模型和业务进程的框架,企业内所有的应用程序都需要采用这个框架来使用常见数据、逻辑和业

副标题#e#

漏洞分析
Apache OFBiz是一个开源的企业资源规划(ERP)系统,它提供了一系列企业应用程序来帮助企业自动化实现很多业务流程。它包含了一个能提供常见数据模型和业务进程的框架,企业内所有的应用程序都需要采用这个框架来使用常见数据、逻辑和业务处理组件。除了框架本身之外,Apache OFBiz还提供了包括会计(合同协议、票据、供应商管理、总账)、资产维护、项目分类、产品管理、设备管理、仓库管理系统(WMS)、制造执行/制造运营管理(MES/MOM)和订单处理等功能,除此之外,还实现了库存管理、自动库存补充、内容管理系统(CMS)、人力资源(HR)、人员和团队管理、项目管理、销售人员自动化、工作量管理、电子销售点(ePOS)、电子商务(电子商务)和scrum(开发)等多种功能。

Apache OFBiz使用了一系列开源技术和标准,比如Java、JavaEE、XML和SOAP。

超文本传输协议是一种请求/响应协议,该协议在 RFC 7230-7237中有详细描述。请求由客户端设备发送至服务器,服务器接收并处理请求后,会将响应发送回客户端。一个HTTP请求由请求内容、各种Header、空行和可选消息体组成:

Request = Request-Line headers CRLF [message-body] 

 

Request-Line = Method SP Request-URI SP HTTP-Version CRLF 

 

Headers = *[Header] 

 

Header = Field-Name “:” Field-Value CRLF 

CRLF代表新的行序列回车符(CR),后跟换行符(LF),SP表示空格字符。参数将以键值对的形式通过Request- URI或message-body由客户端传递给服务器,具体将取决于Method和Content-Type头中定义的参数。比如说在下面的HTTP请求样本中,有一个名为“param”的参数,其值为“1”,使用的是POST方法:

POST /my_webapp/mypage.htm HTTP/1.1 

 

Host:  

 

Content-Type: application/x-www-form-urlencoded 

 

Content-Length: 7 

 

  

 

param=1 

Java序列化 Java支持对对象进行序列化操作,使它们额能够被表示为紧凑和可移植的字节流,然后可以通过网络传输这个字节流,并将其反序列化以供接收的servlet或applet使用。下面的示例演示了如何将一个类进行序列化并在随后提取数据:

public static void main(String args[]) throws Exception{ 

 

   //This is the object we're going to serialize. 

 

   MyObject1 myObj = new MyObject1(); 

 

   MyObject2 myObj2 = new MyObject2(); 

 

   myObj2.name = "calc"; 

 

   myObj.test = myObj2; 

 

  

 

   //We'll write the serialized data to a file "object.ser" 

 

   FileOutputStream fos = new FileOutputStream("object.ser"); 

 

   ObjectOutputStream os = new ObjectOutputStream(fos); 

 

   os.writeObject(myObj); 

 

   os.close(); 

 

  

 

   //Read the serialized data back in from the file "object.ser" 

 

   FileInputStream fis = new FileInputStream("object.ser"); 

 

   ObjectInputStream ois = new ObjectInputStream(fis); 

 

  

 

   //Read the object from the data stream, and convert it back to a String 

 

   MyObject1 objectFromDisk = (MyObject1)ois.readObject(); 

 

   ois.close(); 

 

#p#副标题#e#

所有的Java对象都需要通过Serializable或Externalizable接口来进行序列化,这个接口实现了writeObject()/writeExternal()和readObject()/readExternal()方法,它们会在对象序列化或反序列化时被调用。这些方法能够在序列化和反序列化过程中通过修改代码来实现自定义行为。

本文来自网络,不代表站长网立场,转载请注明出处:https://www.tzzz.com.cn/html/fuwuqi/anquan/2021/0609/10197.html

作者: dawei

【声明】:站长网内容转载自互联网,其相关言论仅代表作者个人观点绝非权威,不代表本站立场。如您发现内容存在版权问题,请提交相关链接至邮箱:bqsm@foxmail.com,我们将及时予以处理。
联系我们

联系我们

0577-28828765

在线咨询: QQ交谈

邮箱: xwei067@foxmail.com

工作时间:周一至周五,9:00-17:30,节假日休息

返回顶部