博客
关于我
BugkuCTF_Web——“web基础$_POST”、“计算器”、“矛盾”、“web3”、“你必须让他停下”
阅读量:796 次
发布时间:2019-03-25

本文共 1056 字,大约阅读时间需要 3 分钟。

网络安全实战训练 | flag获取解 pháp

网络安全漏洞的挖掘与利用,是如今的热门话题。以下是一些经典的web安全挑战及解决方案,供安全爱好者参考。


1. web基础$_POST

目标:通过$_POST获取flag

思路:我们需要找到能够提交给web服务器的方法,从而获取隐藏的flag信息。常见的web安全方法包括xss漏洞、csrf攻击以及利用$_POST直接获取参数值等。

解决方案:使用浏览器插件Hackbar(推荐使用Edge浏览器或Microsoft商城版本的插件)来测试网页输入框的值。按照提示,输入特定的命令序列(如sssa),发现flag值为flag{bugku_get_ssseint67se}


2. 计算器

描述:网页是一个简单的数字运算器

尝试:网页的maxlength属性限制了输入长度,默认无法输入超过一定数量的字符。

解决方案:使用F12开发者工具检查页面源码。定位maxlength属性,修改或删除它后尝试提交表单。正确答案为flag{CTF-bugku-0032}


3. 矛盾

描述:PHP代码中存在条件矛盾

代码逻辑如下:

$num=$_GET['num'];if(!is_numeric($num)){  echo $num;if($num==1)echo 'flag{**********}';}

尝试:网页提示num必须是数字,但同时要求num=1却不能输出数字。

解决方案:将num设置为1a(非纯数字但值为1),则满足num==1的条件输出flag{bugku-789-ps-ssdf}


4. Web3

描述:页面涉及重定向或动态生成

尝试:尝试禁用JavaScript,发现页面无法加载。或使用view-source直接查看源码。

解决方案:发现源码中存在HTML注释:

解码后,flag值为flag{KEY{J2sa42ahJK-HS11III}}


5. 你必须让他停下

描述:动态页面与反爬机制

尝试:禁用JavaScript后仍无法获取flag,怀疑是无限刷新保护机制。

解决方案:使用Fiddler抓包工具,发现页面返回的数据是空的网页。但某次抓包发现页面内容长度为421,解码后得到flag{dummy_game_1s_s0_popular}



通过这些实战挑战,我们可以看出,web安全中既需要理论知识,更需要实践操作力。掌握这些基础方法,将有助于你在未来的网络安全挑战中脱颖而出。如果对某一题有疑惑或需要进一步说明,请探讨在评论区。

转载地址:http://nnpuk.baihongyu.com/

你可能感兴趣的文章
Vue过渡 & 动画---vue工作笔记0014
查看>>
Netty 异步任务调度与异步线程池
查看>>
Netty 的 Handler 链调用机制
查看>>
Netty 编解码器和 Handler 调用机制
查看>>
Netty 编解码器详解
查看>>
Netty 解决TCP粘包/半包使用
查看>>
Netty 调用,效率这么低还用啥?
查看>>
Netty 高性能架构设计
查看>>
Netty+Protostuff实现单机压测秒级接收35万个对象实践经验分享
查看>>
Netty+SpringBoot+FastDFS+Html5实现聊天App详解(一)
查看>>
netty--helloword程序
查看>>
netty2---服务端和客户端
查看>>
【Flink】Flink 2023 Flink易用性和稳定性在Shopee的优化-视频笔记
查看>>
Netty5.x 和3.x、4.x的区别及注意事项(官方翻译)
查看>>
netty——bytebuf的创建、内存分配与池化、组成、扩容规则、写入读取、内存回收、零拷贝
查看>>
netty——Channl的常用方法、ChannelFuture、CloseFuture
查看>>
netty——EventLoop概念、处理普通任务定时任务、处理io事件、EventLoopGroup
查看>>
netty——Future和Promise的使用 线程间的通信
查看>>
netty——Handler和pipeline
查看>>
Vue输出HTML
查看>>