实验步骤:
Web应用程序文件包含安全攻防
任务环境说明:
服务器场景:WebServ2003(用户名:administrator;密码:空)
服务器场景操作系统:Microsoft Windows2003 Server
服务器场景安装服务/工具1:Apache2.2;
服务器场景安装服务/工具2:Php6;
服务器场景安装服务/工具3:Microsoft SqlServer2000;
服务器场景安装服务/工具4:EditPlus;
网络拓扑:01-WebServ2003--02-AttWinXp
windows server 2003
用户:administrator
密码:空
网络拓扑
data:image/s3,"s3://crabby-images/0d827/0d827f6506740ac9e27851c996f7ee6853460950" alt=""
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
实战
=========================================================================
访问WebServ2003服务器场景,"/"->" Display Uploaded's File Content",分析该页面源程序,找到提交的变量名,并将该变量名作为Flag(形式:name="变量名")提交;
查看server2003的ip地址
data:image/s3,"s3://crabby-images/8f429/8f429d35a3cd8cdf80801795feef1d6865854fe8" alt=""
访问2003的http服务
data:image/s3,"s3://crabby-images/3fef1/3fef1e75d22829f9cc9ece5a37fc9f1b29f95320" alt=""
可以使用万能用户、任意密码登录(密码我直接随便按了几个)
' union select * from users--
data:image/s3,"s3://crabby-images/bd12d/bd12deaecbcc91ad3dad5073ed4bb8b062c03f4f" alt=""
点击Submit,成功进入。
data:image/s3,"s3://crabby-images/e8706/e870652a44db5c026320cf501fe17d734130a147" alt=""
data:image/s3,"s3://crabby-images/8c8fd/8c8fd7123fff643a9fcc76203b4630afb12cb057" alt=""
点击倒数第二个,也就是 Display Uploaded's File Content
右键,查看源文件
data:image/s3,"s3://crabby-images/78847/788479963ea10b4731ef55ec391a36ade34f231d" alt=""
找到变量名
data:image/s3,"s3://crabby-images/82bbe/82bbe584dbd937963182d391fd21d93736ded7b0" alt=""
本题提交Flag:【 name="filename" 】
=========================================================================
对该任务题目1页面注入点进行渗透测试,通过php://filter协议使当前页面以Base64编码方式回显WebServ2003服务器场景访问日志文件:AppServ/Apache2.2/logs/flag.log的内容,并将注入语句作为Flag提交;
php://filter/read=convert.base64-encode/resource=../Apache2.2/logs/flag.log
data:image/s3,"s3://crabby-images/5dff5/5dff5d53c8db8ecf0800f741749f3d1085d958d7" alt=""
本题提交Flag:【php://filter/read=convert.base64-encode/resource=../Apache2.2/logs/flag.log】
=========================================================================
对该任务题目2页面注入点进行注入以后,将当前页面以Base64编码方式回显内容作为Flag提交;
data:image/s3,"s3://crabby-images/13345/133455534edfa0fe182e6ebfc0819fa84db8d6e0" alt=""
本题提交Flag:
【 V2l0aCBncmVhdCBwb3dlciBjb21lcyBncmVhdCByZXNwb25zaWJpbGl0eS4= 】
=========================================================================
通过PHP函数对题目3中Base64编码回显内容进行解码,并将解码内容作为Flag提交;
输入php://filter/read=convert-encode/resource=../Apache2.2/logs/flag.log
php://filter/read=convert-encode/resource=../Apache2.2/logs/flag.log
data:image/s3,"s3://crabby-images/0271e/0271ea44f1bd99b60c30d85b045e688df8f6e1a3" alt=""
本题提交Flag:【 With great power comes great responsibility. 】
进入WebServ2003服务器场景的目录,找到DisplayFileCtrl.php文件,使用EditPlus工具打开并填写该文件中空缺的F1、F2、F3、F4的值,使之可以抵御文件包含渗透测试,并提交Flag(形式:F1|F2|F3|F4);
首先注释下面这段代码
data:image/s3,"s3://crabby-images/c3861/c3861369572450d45c16f3db7cfa9ff6017896a1" alt=""
修改上面这段
data:image/s3,"s3://crabby-images/2ad48/2ad4827c1b120b24be3c5704077a2894a4ef5648" alt=""
修改点和参数:
F1:..
F2:strstr
F3:empty
F4:@readfile
修改后:
data:image/s3,"s3://crabby-images/1e38b/1e38bd276cac94a78ce6ed871e85e94ea7d062ce" alt=""
再次对该任务题目1页面注入点进行渗透测试,验证此次利用该注入点对WebServ2003服务器场景进行文件包含渗透测试无效,并将回显页面源文件内容作为Flag提交;
再次进行渗透
data:image/s3,"s3://crabby-images/a0cb4/a0cb48363577baef1f0682530b05a029cb69f4a7" alt=""
本题提交Flag:
【 Illegal input!</br><a href='DisplayFile.php'>Display Uploaded's File Content</a></br>】
=========================================================================