记一次文件包含刷题(伪协议篇)

每种协议的具体用法可自行查阅,这里只做分析

第一题

未做任何防护,访问文件就能拿到flag

第二题

未告诉flag文件名,便考虑进行命令执行

使用php://input绕过,进行命令执行

第三题

allow_url_fopen :on

allow_url_include:on

发现上面两个条件都为on,便考虑data://

data://text/plain,<?php system('ls'); ?>

data://text/plain,<?php system('cat flag_21843732549.txt'); ?>

第四题

告诉flag的地址,但是不显示文件内容,考虑用php://filter进行读取

php://filter/convert.base64-encode/resource=flag.php

读取解码便是flag

第五题

通过观察代码发现这里对传入的参数进行了二次读取,所以也用php://input

然后传入参数进行匹配就好了

第六题

发现有文件上传点,并且支持zip文件上传,便考虑phar://和zip://

先将一句话木马shell.php压缩成shell.zip,并且上传。

如果不让上传zip文件,那就将shell.zip的后缀改成png或者jpg再上传。

用蚁剑连接http://x.x.x/?file=phar://uploads/8519c12b20eb3f740c896055a5cec49a.zip/shell

第七题

根据观察可以发现这是一个利用PHP_SESSION_UPLOAD_PROGRESS进行文件包含的题目

1.**当session.upload_progress.enabled = On时,**表示当浏览器向服务器上传一个文件时,PHP将会把此次文件上传的详细信息(如上传时间、上传进度等)存储在session当中

2.保存的路径在session.save_path

  1. 当session.use_strict_mode=Off时,PHPSESSID的值可控

4.默认会根据PHPSESSID生成一个文件 ,假设我传入为123,那么便会在/var/lib/php/sessions下生成一个sess_123文件来记录临时信息

5.当session.upload_progress.cleanup=On时,生成的sess_123文件会在上传完毕后强制删除,这时候我们需要在上传完成前去访问缓存.

6.我们通过传入PHPSESSID=123,生成一个sess_123文件。

然后修改PHP_SESSION_UPLOAD_PROGRESS,也就是参数a。来传入php代码。

最后利用include包含sess_123文件,来达到执行的目的。

传如的代码会生成一个木马文件,接着连接上就好了。

<?php fputs(fopen("456.php", "w"), '<?php @eval($_POST["shell"]); ?>'); ?>

相关推荐
FreeBuf_10 分钟前
“lc“键漏洞:LangChain高危缺陷(CVE-2025-68664)使提示注入攻击可窃取机密
安全·web安全·langchain
叫我莫言鸭27 分钟前
关于word生成报告的POI学习
学习·word
马剑威(威哥爱编程)27 分钟前
【鸿蒙学习笔记】基于HarmonyOS实现申请Push Token的功能
笔记·学习·harmonyos
jjjxxxhhh12334 分钟前
2025年底 -对工作做个跨年总结
学习
微爱帮监所写信寄信1 小时前
微爱帮监狱寄信写信系统后台PHP框架优化实战手册
android·开发语言·人工智能·网络协议·微信·https·php
白帽子黑客罗哥1 小时前
网络安全防护技术与实战策略:从基础防御到前沿应对
安全·web安全·php
Tandy12356_1 小时前
手写TCP/IP协议栈——TCP结构定义与基本接口实现
c语言·网络·c++·网络协议·tcp/ip·计算机网络
安全渗透Hacker1 小时前
PHPStudy快速搭建DVWA靶场完整指南
安全·web安全·网络安全·安全性测试
快点好好学习吧1 小时前
PHP程序员到底为什么要学习正则表达式?使用场景是什么?底层原理是什么?
学习·正则表达式·php
小胡想找到工作1 小时前
一起学习javascript-正则表达式
学习