[CTFSHOW][WEB入门]nodejs部分WP

94 篇文章 21 订阅
67 篇文章 6 订阅

前言

nodejs从入门到挖坟,今天早上刚刚学了一点,成功了,比较开心,入门了新的领域

web334

下载源码下来在user.js里面发现了用户名和密码,群主比较坑哈,搞了个大写,明明是小写,ctfshow密码我忘了压缩包懒得下

web335

方法一

一道Node.JS的RCE
在这里插入图片描述
之后cat fl00g.txt即可
在这里插入图片描述

方法二

方法太多了随便写一个吧
global.process.mainModule.constructor._load('child_process').exec('calc')

web336

方法一

先用上一题paylaod
在这里插入图片描述
尝试绕过姿势,也不行
在这里插入图片描述
那么试一下读取下文件呢,看看过滤了啥,通过全局变量读取当前目录位置
在这里插入图片描述
很明显过滤了这两个
在这里插入图片描述
尝试本地绕过本地打通
在这里插入图片描述
把加号url编码(浏览器解析特性+会成为空格好像)在这里插入图片描述
出结果
在这里插入图片描述

方法二

首先读取目录下文件,看到flag了
在这里插入图片描述
在这里插入图片描述

方法三

在这里插入图片描述

web337

数组绕过,很简单,不写过程了

web338

考点:nodejs原型污染
推荐大家看看这篇文章,不用看多一点点就好,很简单的,俺也是现学的相信自己继承与原型链
关键点是这里

router.post('/', require('body-parser').json(),function(req, res, next) {
  res.type('html');
  var flag='flag_here';
  var secert = {};
  var sess = req.session;
  let user = {};
  utils.copy(user,req.body);
  if(secert.ctfshow==='36dboy'){
    res.end(flag);
  }else{
    return res.json({ret_code: 2, ret_msg: '登录失败'+JSON.stringify(user)});  
  }
});

主要是utils.copy(user,req.body);是利用点
在这里插入图片描述
此时,因为原型污染,secret对象直接继承了Object.prototype,所以就导致了secert.ctfshow==='36dboy'

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 13
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值