filterchain加string.strip_tags随意构造字符串

2 篇文章 0 订阅
1 篇文章 0 订阅
string.strip_tags

使用此过滤器等同于用 strip_tags()函数处理所有的流数据。可以用两种格式接收参数:一种是和 strip_tags()函数第二个参数相似的一个包含有标记列表的字符串,一种是一个包含有标记名的数组。strip_tags — 从字符串中去除 HTML 和 PHP 标记.该函数尝试返回给定的字符串 str 去除空字符、HT

strip_tags() 函数剥去字符串中的 HTML、XML 以及 PHP 的标签。

注释:该函数始终会剥离 HTML 注释。这点无法通过 allow 参数改变。

注释:该函数是二进制安全的。

ML 和 PHP 标记后的结果

先测试以下功能

<?php

echo strip_tags($_POST[1]);

发现去除了<>标签,

在标签中加内容会发生啥

把标签中的内容都去掉了

这样就可以通过string.strip_tags去掉标签中的内容,当然<一个标签后的内容也可以去掉

abc<?aaaaa通过过滤就变成了abc

filterchain可以通过字符转换的差异构造出任意字符,原理可看探姬博客

详浅谈Filter链 - 探姬的技术测试

详细看这个项目:

https://gist.github.com/loknop/b27422d355ea1fd0d90d6dbc1e278d4d

当然也有可以直接用来梭的脚本:

https://github.com/synacktiv/php_filter_chain_generator

如果构造出要的字符然后在字符后面加个<?php可以把之后的数据清空,然后只剩下需要的字符了

比如我要构造XYCTF

通过脚本构造XYCTF<?

然后在最后手动加个string.strip_tags过滤器,就可以吧标签后的数据清空

举个死亡die的例子

部分代码

$content = $secret . $filename;
file_put_contents($filename, $content);

其中$secret为<?php die();

我们要让死亡die必须把它消掉或者通过编码绕过
写文件时加个?>标签会闭合<?php die();然后 string.strip_tags把标签中的内容去掉了
之后就可以上传我们想传的内容。
php://filter/write=string.strip_tags/?>php_value auto_prepend_file
flag\n#/resource=.htaccess
XYCTF有道用了此功能
<?php
highlight_file(__FILE__);
error_reporting(0);

$p=$_GET['p'];

if(preg_match("/http|=|php|file|:|\/|\?/i", $p))
{
    die("waf!");
}

$payload="php://filter/$p/resource=/etc/passwd";

if(file_get_contents($payload)==="XYCTF"){
    echo file_get_contents('/flag');
} 

$p只能传入filter过滤器链,其他被过滤了

我们构造XYCTF<然后可以通过string.strip_tags把标签之后的乱码消掉就得到XYCTF了

  • 24
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值