NSSCTF-Web题目22(弱比较、数组绕过)

目录

[鹤城杯 2021]Middle magic

1、题目

2、知识点

3、思路

[WUSTCTF 2020]朴实无华

4、题目

5、知识点

6、思路


[鹤城杯 2021]Middle magic

1、题目

2、知识点

代码审计,弱比较、数组绕过

3、思路

 打开题目,出现源代码,我们进行审计

1、

这里要我们上传一个aaa变量,然后用了preg_replace函数

preg_replace:

   $aaa = preg_replace('/^(.*)level(.*)$/', '${1}<!-- filtered -->${2}', $_GET['aaa']);

意思是:将aaa变量中的level字段替换成<!-- filtered -->

preg_match:

if(preg_match('/pass_the_level_1#/', $aaa))

意思是aaa参数的内容是pass_the_level_1#

这里的难点是要绕过preg_replace函数,因为它会将level替换掉,

因为preg_replace函数只匹配第一行的数据,不能匹配多行的字符,所以我们可以使用换行符进行绕过

payload:

?aaa=%0apass_the_level_1%23

2、

这里需要POST上传admin和root_pwd两个参数,首先对他们进行弱比较(==),然后进行sha1强比较(===),这里可以使用数组绕过,因为弱比较只比较类型,不比较值,然后sha1对数组进行加密后为空,所以也可以绕过

payload:

admin[]=1&root_pwd[]=2

3、

这里要POST上传一个level_3参数,且会对其内容进行json解码,所以我们需要上传一个json格式的数据,接着跟内置的result变量进行弱比较

这里可以使用{"result":字符串},或者{"result":0}

payload:

level_3={"result":0}  因为PHP纯字符与0进行弱比较时为True

或者

{"result":ssss}  因为json格式的字符串解码后会变成一个数组

得到flag:NSSCTF{c8dd707c-eb31-484b-826a-d616e09a599c}


[WUSTCTF 2020]朴实无华

4、题目

5、知识点

弱比较,代码审计

6、思路

访问题目,发现没有什么提示,用目录扫描看看

访问robots.txt

出现一个页面,访问一下看看

结果也没什么用,之前出现一个字段,User-agent,抓包看看

发现隐藏的页面:/fl4g.php

得到源码,正戏来了

1、level1

这里要我们上传一个num变量,但是要小于2020,但又要大于2021

intval()

这里可以1e10,就可以绕过比较了

2、level2

这里上传一个md5变量,且它的值跟md5加密后的值相同,百度一下

0e215962017

这样就绕过了

3、level3

这里会执行system($get_flag),也就是我们可以传进行系统命令,然后执行

if(!strstr($get_flag," ")

如果有get_flag有空格,则为false,所以这也是对空格的过滤

对空格的绕过有:${IFS}$9 、{IFS} 、$IFS 、${IFS}、$IFS$1(其他数字也行,不一定要1)、IFS等

str_ireplace

$get_flag = str_ireplace("cat", "wctf2020", $get_flag);

如果get_flag变量的内容有cat,则替换成wctf2020,也就是过滤了cat

绕过:可以用tac

先查看有什么文件

payload:

?num=1e10&md5=0e215962017&get_flag=tac${IFS}$9fllllllllllllllllllllllllllllllllllllllllaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaag

得到flag:NSSCTF{ee074295-8182-42f6-b291-509d02b15df4}


这篇文章就先写到这里了,哪里不懂的或者哪里不足的欢迎指出!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/865517.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

强行仅用time.localtime制作“日历牌”——全程记录“顶牛”“调戏”我的AI学习搭子

强行只用time.localtime制作“日历牌”&#xff0c;码好代码试炼通过&#xff0c;想榨取ai智能优化算法&#xff0c;结果失败。本文详细记录“顶牛”全过程。 (笔记模板由python脚本于2024年07月01日 19:16:26创建&#xff0c;本篇笔记适合喜欢python&#xff0c;喜欢搞“事儿”…

打卡第二十七天 455分发饼干 376摆动序列

第一题&#xff1a; 原题链接&#xff1a;455. 分发饼干 - 力扣&#xff08;LeetCode&#xff09; 思路&#xff1a; 将大的饼干来满足胃口大的孩子。 先将小孩子的胃口和饼干的尺寸进行排序。然后从后往前遍历胃口&#xff0c;饼干的尺寸也从后往前。如果饼干尺寸大于等于…

Android系统adb shell dumpsys activity processes

在Android系统中&#xff0c;adb shell dumpsys activity processes 命令是一个非常强大的工具&#xff0c;用于获取当前系统中所有运行进程的详细信息&#xff0c;包括它们的状态、内存使用情况、任务栈等。这对于开发者来说非常有用&#xff0c;尤其是在调试应用、分析系统性…

安装Gitlab+Jenkins

GItlab概述 GitLab概述&#xff1a; 是一个利用 Ruby on Rails 开发的开源应用程序&#xff0c;实现一个自托管的Git项目仓库&#xff0c;可通过Web界面进行访问公开的或者私人项目。 Ruby on Rails 是一个可以使你开发、部署、维护 web 应用程序变得简单的框架。 GitLab拥有与…

【hot100】跟着小王一起刷leetcode -- 739. 每日温度

【hot100】跟着小王一起刷leetcode -- 739. 每日温度 739. 每日温度题目解读思路 代码总结 739. 每日温度 题目解读 739. 每日温度 老规矩&#xff0c;咱先看下题目。总结下来就是&#xff0c;你要返回一个answer数组&#xff0c;answer[i]中存储的应该是temperatures数组中…

Python在智慧农业中的实践:智能灌溉系统的自动化控制

Python在智慧农业中的实践&#xff1a;智能灌溉系统的自动化控制 Python凭借其强大的库支持和易读性&#xff0c;正逐步渗透到各行各业&#xff0c;成为推动技术革新的重要力量。今天&#xff0c;我们将聚焦智慧农业&#xff0c;通过一个生动的案例&#xff0c;探索Python如何…

解决ps暂存盘已满的问题

点击编辑->首选项->暂存盘 ps默认暂存盘使用的是c盘&#xff0c;我们改成d盘即可 然后重启ps

​​​​​​​​​​​​​​Spark Standalone集群环境

目录 Spark Standalone集群环境 修改配置文件 【workers】 【spark-env.sh】 【配置spark应用日志】 【log4j.properties】 分发到其他机器 启动spark Standalone 启动方式1&#xff1a;集群启动和停止 启动方式2&#xff1a;单独启动和停止 连接集群 【spark-shel…

详细介绍MySQL的索引(下)

索引的使用 同一条数据在未创建索引的情况下耗时&#xff1a; nick字段是未创建索引的 select * from t_user WHERE nick 邹丽;SHOW PROFILES; 耗时为&#xff1a; user_account字段创建了唯一索引 select * from t_user WHERE user_account 13781945844;SHOW PROFILES;…

PHP验证日本固定电话号码

日本电话号码格式众多&#xff0c;验证起来比较头大&#xff0c;现在咱们来一个简单的总结哈 为了简单起见&#xff0c;使用PCRE 函数preg_match通过匹配正则表达式来实现验证。 function checkGdTelLandline(string $str): int|false {return preg_match("/\A0(\d{1}[-…

git commit 怎么跳过 husky, commitlint 的检查

我们引入 husky, commitlint 是为了保障代码入库的质量&#xff0c;但是有些时候&#xff0c;我们需要应急处理&#xff0c;比如你在升级框架时&#xff0c;通常不是一两天能解决的&#xff0c;可能希望临时把代码提交到一个分支&#xff0c;而这个时候&#xff0c;你改造的代码…

0122__linux之eventfd理解

linux之eventfd理解-CSDN博客 Linux fd 系列 — eventfd 是什么&#xff1f;-CSDN博客

安装 VisualSVN Server提示HTTP服务无法启动的问题解决

安装 VisualSVN Server 版本&#xff1a;VisualSVN-Server-5.4.0-x64 安装包在安装到一半的时候&#xff0c;弹窗提示&#xff1a;HTTP服务无法启动&#xff0c;网上找了一大堆&#xff0c;说是service里面更改用户为本地用户什么的都没用用&#xff0c;点右键也无法启动。 …

配置Uptime Kuma固定前缀

在做ICT集成项目时&#xff0c;遇到需要对现网接口进行拨测的需求。搜索后尝试使用开源的Uptime Kuma组件完成现网接口拨测。 但该项目有个问题就是默认不支持配置固定前缀&#xff0c;这对现网进行请求转发会造成较大的影响。通过查看该项目的github后找到了问题的解决方案。S…

systemd指令之journalctl指令

systemd的历史由来及概述 在Linux系统的发展历程中&#xff0c;init进程一直是系统启动的核心。然而&#xff0c;这种传统的启动方式存在两个主要缺点&#xff1a; 启动时间长&#xff1a;init进程采用串行启动机制&#xff0c;只有在前一个进程启动完成后&#xff0c;才能启…

web自动化(三)鼠标操作键盘

selenuim 键盘操作 import timefrom selenium.webdriver.common.keys import Keys from selenium.webdriver.common.by import By from selenium.webdriver.support import expected_conditions as EC from selenium.webdriver.support.wait import WebDriverWait from selen…

SQL语言基础特点、数据库系统

一、SQL的概述 &#xff08;1&#xff09; SQL全称&#xff1a; Structured Query Language&#xff0c;是结构化查询语言&#xff0c;用于访问和处理数据库的标准的计算机语言。 &#xff08;2&#xff09;SQL语言1974年由Boyce和Chamberlin提出&#xff0c;并首先在IBM公…

安卓h5打包系统设计

设计一个安卓H5打包系统,主要是为了将H5应用高效、便捷地转换为原生安卓应用(APK),以适应不同场景下的需求。下面是一个基本的设计框架: 1. 系统目标与需求分析 目标:实现一个用户友好的界面,使无编程基础的用户也能轻松将H5项目打包成安卓APP。需求: 支持H5项目上传与…

Leetcode秋招冲刺(专题10--12)

专题10&#xff1a;动态规划 题目509&#xff1a;斐波那契数&#xff08;NO&#xff09; 解题思路&#xff1a;动态五部曲 动态五部曲&#xff1a;这里我们用一个一维数组来保存递归的结果 确定dp数组以及下标的含义 dp[i]的定义为&#xff1a;第i个数的斐波那契数值是dp[i]…

手写数组去重

方法1-判断相邻元素 function _deleteRepeat(arr){if(!Array.isArray(arr)){throw new Error(参数必须是数组)}let res[];// 使用slice创建arr的副本&#xff0c;并排序let sortArrarr.slice().sort((a,b)>a-b);for(let i0;i<sortArr.length;i){if(isortArr.length-1||s…