CTFShow-WEB入门篇文件上传详细Wp(151-170)

简介: CTFShow-WEB入门篇文件上传详细Wp(151-170)

CTFShow 平台:https://ctf.show/

文件上传:

Web151:

考点:前端绕过


F12修改源代码 exts后面png改为php 这样就可以上传php的文件了,然后蚁剑直接连接



可以使用插件进行post获取flag。

ctfshow{ec07a689-3422-439f-aeda-25e174588e7e}


Web152:

考点:后端不能单一校验

就是要传图片格式,抓个包传个png的图片 然后bp抓包修改php后缀解析 然后放包 显示上传成功 蚁剑连即可。

ctfshow{3129d70b-491d-411e-811f-b2eafca203c9}


Web153:

考点:后端不能单一校验(黑名单绕过)


.htaccess在绕过文件上传的限制中,通常在 Apache 全局配置文件 httpd.conf 中

有这样一条配置:AddType application/x-httpd-php .php .phtml或者

SetHandler application/x-httpd-php 将所有文件都解析为 php 文件


这里我们尝试.htaccess(因为它只适用于Apache)所以不行,这里要使用.user.ini

php.ini 是 php 的一个全局配置文件,对整个 web 服务起作用;而.user.ini 和.htaccess 一样是目录的配置文件,.user.ini 就是用户自定义的一个 php.ini,通常用这个文件来构造后门和隐藏后门。


这里先上传一个内容为:auto_prepend_file=1.png得png,然后在正常传一个带图片得一句话木马即可。这里如果不懂可以参考:.htaccess 和.user.ini 配置文件妙用



ctfshow{dcea4490-2c26-45a6-8027-3c19c8467554}

Web154:

考点:php关键字过滤


这里方法和上面一样传一个1.png(带一句话木马的文件)然后在上传.user.ini 文件即可

<?=eval($_POST[a]);?>## <?=相当于<?php echo



9da81c1a201e4427bbe43825ba13ba26.png


71b1e19320db4e75a4684a16e3a0dfa6.png

00d72ae9ab7f4fe58ac22388b48827cd.png






00d72ae9ab7f4fe58ac22388b48827cd.png



8f725b6b01164cd7be268d6056073a8f.png


ctfshow{503e93c8-c013-4509-9551-5431a3b5a5ef}

Web155:


这里的方法和上一题一样,ok在做一遍 老样子先上传.user.ini.png1.png然后直接访问/upload/index.php/即可。

ctfshow{25d0b333-d5f2-4761-85a0-bed828314b6d}


Web156:

考点:过滤字符[][]可以可以使用{}代替。

这里也很简单 段标签的基础上改成{}即可 <?=eval($_POST{a});?


这里还有个小技巧如果知道flag的位置可以直接使用system()函数执行 查询即可 <?=system("tac ../f*");?>



ctfshow{dec5a89b-b30b-49fd-94f3-c4c739292799}

Web157:

考点:过滤字符串 过滤了{};


这里可以使用命令执行:<?=system("tac ../f*");?>直接访问/upload/

ctfshow{f7322ad8-f548-4abd-a17b-2e950fa9de2b}



Web158:

同上 一样的方法即可。

ctfshow{ee9f76b3-2182-4276-904f-5bfaf2afcb8f}


Web159:

这里就不能使用那种上面的方法啦,因为过滤了括号,这里显示上传报错的信息。


这里使用 `` 反引号过滤绕过即可:

<?=`tac ../f*`?>
• 1






ctfshow{f84bd0d7-6f86-4de2-bdc9-b51664a4d61c}

Web160:

考点:还是过滤字符串 这里又过滤了log 字符串 所以使用拼接绕过


可以尝试 日志包含绕过 : <?=include"/var/lo"."g/nginx/access.lo"."g"?>


还是先上传.user.ini.png进行解析 然后包含/upload/index.php/ 然后服务器是nginx


知识点:nginx的默认日志路径是:/var/log/nginx/access.log

0f1736a15ace46a7adad275202f5fc46.png


直接查看源代码不然太多了日志看不出

ctfshow{8fcd0b60-1cfc-4045-b07f-9b36580c8f4f}


Web161:

考点:文件头的校验

文件头校验扩展(这里用gif


.JPEG;.JPE;.JPG,”JPGGraphic File”

.gif,”GIF 89A”

.zip,”Zip Compressed”

.doc;.xls;.xlt;.ppt;.apr,”MS Compound Document v1 or Lotus Approach

  1. APRfile”



使用16进制编辑器在.user.ini.png 中添加png 文件头 89 50 4E 47 0D 0A 1A 0A 1.png也添加也会成功!!


访问index.php修改User-Agent为:<?php eval($_POST[a]);?> 然后hackbar 或者蚁🗡连接!



751076deccfe4dd291820e7ba034ab52.png

tfshow{9504ed8b-aebc-4ec0-8f91-45560fc9dc4e}

Web162:

考点:前端校验



Web167:

考点:.htaccess

这回服务器是Aapache2 所以使用.htaccess 写入:AddType application/x-httpd-php.jpg.jpg后缀的文件解析 php



Web169:

考点:前端校验,日志包含

前端做了校验只能传zip文件,后端又做了图片文件检查.过滤了<>php

先上传一个png 发现不符合 看来是过滤了 修改后缀为zip 发现可以 然后抓包 把类型改为image/png

先上传一个index.php,然后利用日志包含,上传.user.ini 写入以下内容进行包含然后UA里面写木马

auto_append_file="/var/log/nginx/access.log"
<?php @eval($_POST['a']);?> #User-Agent


f14d4a32c64c4556ab0e3638112a1f2a.png


ctfshow{6c50c591-4ba3-4624-b86e-de790d47fd4a}

Web170:

考点:前端验证,日志包含

先上传一个png 发现不符合 看来是过滤了 修改后缀为zip 发现可以 然后抓包 把类型改为image/png


先上传一个index.php,然后利用日志包含,上传.user.ini 写入以下内容进行包含然后UA里面写木马

auto_append_file="/var/log/nginx/access.log"
<?php @eval($_POST['a']);?> #User-Agent


6765caca5bce4b1ba73a133d360511f4.png

aef0e73482e748ac887e917c98d0334d.png


d30ba91e4f6d4a9a8428512d2019e7c0.png



ctfshow{b563362f-15b8-4937-9571-ebc3e4a1df35}

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
|
20天前
|
关系型数据库 MySQL
web简易开发(二){html5+php实现文件上传及通过关键字搜索已上传图片)}
web简易开发(二){html5+php实现文件上传及通过关键字搜索已上传图片)}
|
11天前
|
前端开发 JavaScript Java
JAVA Web开发入门与实战
本文引导读者入门JAVA Web开发,介绍了Web开发的基本概念,如Servlet、JSP和JavaBean,并详细阐述了JAVA Web开发环境的搭建。文章通过一个在线书店系统的实战项目,展示了从需求分析、数据库设计到前后端开发的全过程,涵盖Servlet处理请求、JSP动态生成页面及表单添加书籍功能。最后,文章提及了进阶技术,如框架使用、前端集成和安全性考虑,鼓励读者深入探索JAVA Web开发的广阔世界。
|
17天前
|
开发框架 中间件 数据库
Django 框架入门全攻略:轻松构建 Web 应用
【5月更文挑战第18天】本文是 Django 入门教程,介绍了如何使用 Django 构建 Web 应用。内容包括安装、项目与应用创建、模型定义、数据库迁移、视图编写、路由配置、模板系统、表单处理和中间件的使用。通过实例展示了 Django 基本流程,帮助初学者快速上手。Django 提供高效工具,便于开发者聚焦业务逻辑,轻松构建功能丰富的 Web 应用。
39 5
|
17天前
|
数据库连接 Python
Flask 框架入门与实践:构建你的第一个 Web 应用
【5月更文挑战第18天】本文介绍了使用 Flask 框架构建第一个 Web 应用的步骤。首先通过 `pip install Flask` 安装框架,然后编写基本的 Python 代码创建应用,包括定义路由和响应。示例展示如何显示 &quot;Hello, World!&quot;,并扩展到显示用户信息的功能。利用模板(如 `index.html`)可使页面更丰富。随着学习深入,可以利用 Flask 的更多特性,如表单处理和数据库连接,来构建更复杂的 Web 应用。本文旨在激发读者对 Flask 和 Web 开发的兴趣,鼓励不断探索和实践。
57 7
|
17天前
|
JSON JavaScript 前端开发
web前端入门到实战:32道常见的js面试题,2024年最新秋招是直接面试吗
web前端入门到实战:32道常见的js面试题,2024年最新秋招是直接面试吗
|
17天前
|
JavaScript 前端开发 程序员
web前端入门到实战:32道常见的js面试题(1),面试哪些
web前端入门到实战:32道常见的js面试题(1),面试哪些
|
20天前
|
缓存 前端开发 Java
15:Servlet 3.0文件上传与下载-Java Web
15:Servlet 3.0文件上传与下载-Java Web
45 5
|
20天前
|
XML 安全 Java
从零手写实现 apache Tomcat-02-web.xml 入门详细介绍
`web.xml`是Java Web应用的核心配置文件,描述应用工作方式。它包含Servlet、Filter和Listener的定义。例如,示例展示了如何配置名为`my`的Servlet处理`/my`请求,`LoggingFilter`拦截所有请求,以及`MyServletContextAttrListener`监听应用事件。`web.xml`是服务器理解应用结构与行为的指南。迷你版Tomcat实现——mini-cat(开源:https://github.com/houbb/minicat)。
|
20天前
|
开发框架 前端开发 安全
Java从入门到精通:2.2.2学习使用Spring框架进行Web应用开发
Java从入门到精通:2.2.2学习使用Spring框架进行Web应用开发
|
20天前
|
设计模式 存储 前端开发
Java从入门到精通:2.2.1学习Java Web开发,了解Servlet和JSP技术,掌握MVC设计模式
Java从入门到精通:2.2.1学习Java Web开发,了解Servlet和JSP技术,掌握MVC设计模式