攻防世界-web-bug

1. 问题描述

没有额外的描述,仅仅是这样的一个登录界面

但是,我们注意到有注册(Register)和找回密码(Findpwd)这俩按钮

注册界面如下:需要输入用户名,密码,生日及地址

找回密码界面如下:需要输入用户名,生日和地址

整体暂时就这些信息了

2. 思路分析

先注册一个账号

注册完后进行登录,可以看到在Personal板块可以看到自己的个人信息

但是没有Manage的权限

好吧,果然是权限不足,那么接下来的目标很明确了,就是获取到admin的权限。这里有两个思路

1. 看是否存在sql注入

2. 既然有找回密码功能,那么看找回密码是否存在逻辑漏洞(这也是实际中常见的一种逻辑漏洞,如果找回密码对用户身份校验不严格,那么容易造成重置别人的密码)

3. 解题过程

3.1 看是否存在sql注入

我这里只是试了下参数uid,这个参数无法sql注入。我这边没有验证其它的参数,不过大家可以试下其它的看是否存在sql注入(根据经验,这种难度的题一般不会是一道简单的sql注入题,所以我这边优先尝试重置密码,当然,重置密码不行,那么就继续分析这里)

3.2 看重置密码是否存在逻辑绕过

第一步:验证身份,我们将我们注册的用户输入进去

第二步:验证成功后,进入到设置新密码的界面

第三步:截取该请求包,修改用户名为admin

可以看到,这里返回重置成功

然后,我们使用admin账号登录看看(密码已经被我们重置成123456了),可以看到,已经登录成功了

登录后,我们发现还是打不开Manage板块,提示IP不允许

这里的IP应该是客户端的IP,这里涉及到的一个知识点是X-Forwarded-For头部字段,用于记录客户端的IP地址,这个头部字段是可以篡改的,我们将该字段加到请求里面,并设置成127.0.0.1

发现还是没有获取到flag,但是返回界面有如下提示

这里说明还有一个隐藏的filemanage模块,该模块有个参数为do可以做文章,我们试试调用该接口

尝试了很多do,发现都是提示操作不正确

这个操作的信息如何获取呢? 这里暂时没有啥思路了,猜了半天没猜出来,看了网上的解法才发现这里是upload

一个文件上传界面,我们看是否能上传一句话木马

果然,这里还是有WAF,限制了上传php,看是否能绕过去,这里尝试了很多绕过方法,最后参考网上做法,使用php5格式文件绕过,这种只需要上传文件即可绕过php的校验并直接获取到flag,当然

最终获取到的flag为cyberpeace{1ee673fcb5dabfca1701e61dadcb4f74}

4. 总结

这道题算是一道综合题,涉及到的知识点非常多:

  1. 重置密码逻辑漏洞

  2. IP限制绕过

  3. 文件上传漏洞及其绕过方式

这些问题一环扣一环,必须解决前面的问题才会给到下一个问题的线索。最终获取flag的过程也是一波三折。非常适合提升自己的安全能力

相关推荐
b0uu3 小时前
2025高校网络安全管理运维赛决赛-取证赛道
安全·web安全
white-persist3 小时前
社会工程学全解析:从原理到实战
网络·安全·web安全·网络安全·信息可视化·系统安全·1024程序员节
介一安全3 小时前
【Web安全】OAuth2.0框架高频安全漏洞分析总结
web安全·网络安全·安全性测试
芯盾时代5 小时前
低空经济网络安全的政策体系构建
安全·web安全·网络安全·低空经济
墨燃.6 小时前
江西省第二届职业技能大赛网络安全赛题 应急响应
安全·web安全
光影少年6 小时前
前端线上出现白屏如何排查问题所在,利用第三方的工具都有哪些
前端·学习·web安全·前端框架
王火火(DDoS CC防护)8 小时前
如何判断服务器是否遭受攻击?
服务器·web安全·网络安全·ddos攻击
小林up11 小时前
【bug解决】[string “tolua.lua“]:1: ‘=‘ expected
bug·lua
roykingw20 小时前
【思想比实现更重要】高并发场景下如何保证接口幂等性
java·web安全·面试
红树林071 天前
beef-xss网页无法访问
安全·web安全·xss