BUU-[极客大挑战 2019]Http

考察点

信息收集

http构造请求数据包

题目


解题步骤

参考文章:https://zhuanlan.zhihu.com/p/367051798

查看源代码

发现有一个a标签,但是οnclick="return false"就是点击后不会去跳转到Secret.php的页面

所以我就自己拼接url

复制代码
http://node4.buuoj.cn:26913/Secret.php

提示不是从 https://Sycsecret.buuoj.cn 这个网址过来的

那么就用hackbar进行referer传值

又给提示要用 "Syclover" browser 这个浏览器访问,那么继续用hackbar加ua值

提示,你只能够在本地读取这个文件!!!

这是限制了文件访问的源地址,可用通过X-Forwarded-For参数来伪造访问的源地址 ,这里可以修改为127.0.0.1或localhost,如下图所示:

最终得到flag

复制代码
flag{823ce916-7669-409d-94b4-a33ab493d35e}

提交flag

总结

最终构造的请求包为:

复制代码
GET /Secret.php HTTP/1.1
Host: node4.buuoj.cn:26913
User-Agent: "Syclover" browser
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,*/*;q=0.8
Accept-Language: zh-CN,zh;q=0.8,zh-TW;q=0.7,zh-HK;q=0.5,en-US;q=0.3,en;q=0.2
Accept-Encoding: gzip, deflate
Connection: close
Referer: https://Sycsecret.buuoj.cn
Upgrade-Insecure-Requests: 1
X-Forwarded-For: 127.0.0.1
DNT: 1

第一步是前端的js代码限制了点击跳转链接的功能

复制代码
onclick="return false"

那么就自己去拼接url,得到响应结果,又要构造请求的数据包请求头,那么最终的请求包为:

复制代码
GET /Secret.php HTTP/1.1
Host: node4.buuoj.cn:26913
User-Agent: "Syclover" browser    # ua代表请求网页浏览器的信息
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,*/*;q=0.8
Accept-Language: zh-CN,zh;q=0.8,zh-TW;q=0.7,zh-HK;q=0.5,en-US;q=0.3,en;q=0.2
Accept-Encoding: gzip, deflate
Connection: close
Referer: https://Sycsecret.buuoj.cn       # 代表从哪个链接跳转到当前网页的
Upgrade-Insecure-Requests: 1
X-Forwarded-For: 127.0.0.1            # 代表访问该服务器的本地资源
DNT: 1
相关推荐
liulilittle4 小时前
OPENPPP2 Code Analysis One
网络·c++·网络协议·信息与通信·通信
叫致寒吧4 小时前
k8s操作(三)
网络·容器·kubernetes
sww_10264 小时前
Netty原理分析
java·网络
用户372824860224 小时前
TCP 连接状态详解
网络协议
飞鸟真人5 小时前
关于python -m http.server的一些安全问题
python·安全·http
星辰烈龙6 小时前
黑马程序员JavaSE基础加强d5
服务器·网络·php
单片机系统设计6 小时前
基于STM32的水质检测系统
网络·stm32·单片机·嵌入式硬件·毕业设计·水质检测
mangge086 小时前
ESP8266 温湿度监测系统教程(SHT30+MAX7219+LeanCloud+HTTP 服务)
网络·网络协议·http
牛奶皮子6 小时前
合并 CSS 文件可以减少 HTTP 请求数,因为每个请求都会带来额外的网络开销
css·网络·http
阿巴~阿巴~7 小时前
“可达”方能“可靠”:深入解析网络层在TCP通信中的基石作用
运维·服务器·网络·网络协议·tcp/ip·ip·tcp