WEB安全第二篇--用文件搞定服务器:任意文件上传、文件包含与任意目录文件遍历
零、前言
最近做专心web安全有一段时间了,但是目测后面的活会有些复杂,涉及到更多的中间件、底层安全、漏洞研究与安全建设等越来越复杂的东东,所以在这里想写一个系列关于web安全基础以及一些讨巧的payload技巧以便于备忘。不是大神、博客内容非常基础,如果真的有人看而且是大牛们,请不要喷我,欢迎指正我的错误(水平有限)。
一、文件上传:
1、这本身是一个功能,但是如果没做好,就成为一个大漏洞。本质:
对上传文件没有进行类型检查,没有做进一步处理,上传文件保存路径泄露,且可访问可执行。
2、文件payload部分:
文件:
(1)一句话小马
(2)大马
(3)其他配置文件.htaccess / crossdomain.xml等
3、上传文件的方式:
(1)直接上传
(2)绕过前端扩展名限制上传(firebug)
(3)绕过后端扩展名限制上传:
#Apache的:1.php.rax.rax.rax。
#lighttpd的:xx.jpg/xx.php。
#IIS的:1.asp;abc.jpg,1.jpg%00.asp。
#Nginx:1.jpg 访问的时候http://localhost/1.jpg/x.php 当版本低时,存在xx.jpg%00.php解析漏洞。
#低版本IIS 会将/asp/目录下的所有文件都按照asp解析,或者webdav目录下上传.txt move 成.asp#
其他手段:
#截断 1.php%00.jpg。
#转换大小写:1.PHP。
#修改文件类型对抗检查content-type。
#终极大招:使用copy a.gif /b + b.php /a c.php 构造包含恶意代码的正常类型文件。
4、防御:
(1)接受文件使用临时路径,然后转存、文件名更换为随机字符串。
(2)不泄露文件最终保存目录。
(3)使用没有解析漏洞的高版本服务器。
(4)严格限制上传扩展名--白名单机制。
(5)做文件类型mime-type检查,对图像文件做二次渲染。
二、文件包含:
1、本质:
当上传的文件不能直接被执行时,可以借助文件包含来搞定。什么是文件包含,其实就是编程中的文件或者包引入
2、分类:
(1)本地文件包含
(2)远程文件包含
3、PHP文件包含:
//All of these function:
/*
include()
include_once()
require()
require_once()
*/
<?php
include($_GET["file"]);
?>
//http://localhost/include.php?file=phpinfo.php
/*
Remote -> allow_url_include = 1 & allow_url_fopen = 1
//http://localhost/include.php?file=//http://localhost/phpphpinfo.php
*/
//pgpinfo.txt:
<?php
phpinfo();
?>
4、JSP文件包含
//分为静态和动态:
//静态
<%@include file="page.txt"%>
//动态:
<%String pages = request.getParameter("file") %>
<jsp:include page="<%=pages>"></jsp:include>
//http://localhost/include.jsp?file=xxx.jsp
5、文件包含的利用:
(1)读取敏感信息:
#/etc/passwd
#/etc/shadow
#my.cnf\php.ini\httpd.conf\access_log等等
(2)远程包含shell小马(一句话)。
(3)配合访问上传的文件。
(4)使用封装协议,也就是说file参数后面可以是各种协议伪协议表示的文件。
(5)绕过waf和防火墙。
6、防御:
(1)包含文件白名单。
(2)用户输入过滤掉. / \ 和伪协议关键词。
(3)包含的文件不允许外部可控。
三、任意目录文件遍历:
1、原因:
web服务器配置不当,导致可以访问到web根目录(www目录)以外的文件,应该是绝对禁止的。且web程序设计没有对访问的目录做检查和限制。
2、比较容易发生的位置:
(1)下载类
(2)图片等文件显示类
3、检测:
(1)file = /etc/passwd 或者 C:/Users/
(2)file = ../../../../../../../../../../../../etc/passwd
(3)http://www.test.com/index/index.php/../../../../../../../../../etc/passwd
4、防御:
1、配置不能访问WEB根目录之外的项目。
2、对可以访问的文件放在一个资源文件夹下。
3、对用户输入的特殊字符例如.和/以及\进行过滤
WEB安全第二篇--用文件搞定服务器:任意文件上传、文件包含与任意目录文件遍历的更多相关文章
- 微信小程序开发技巧总结(二) -- 文件的选取、移动、上传和下载
微信小程序开发技巧总结(二) -- 文件的选取.移动.上传和下载 1.不同类型文件的选取 1.1 常用的图片 视频 对于大部分开发者来说,需要上传的文件形式主要为图片,微信为此提供了接口. wx.ch ...
- 一个PHP文件搞定微信H5支付
/ 更新于 2018-07-02 / 8 条评论 过年期间也坚持要撸码啊接着给博客除草,在这个小除夕是情人节的一天,祝大家新年快乐,情人节能够顺利脱单~~~ 回归正题,这篇文章介绍一下微信H5支付, ...
- (一)React Ant Design Pro + .Net5 WebApi:先搞定服务器,顺手装个Nginx
腾讯云搞定服务器,具体过程就不赘述了,文档都有,咨询客服或者自行百度,体验一下过程. 一. 服务器 1. 云服务器 cvm 1核2G centos8.0 2. 域名注册 www.homejok.com ...
- 《手把手教你》系列技巧篇(五十三)-java+ selenium自动化测试-上传文件-上篇(详细教程)
1.简介 在实际工作中,我们进行web自动化的时候,文件上传是很常见的操作,例如上传用户头像,上传身份证信息等.所以宏哥打算按上传文件的分类对其进行一下讲解和分享. 2.为什么selenium没有提供 ...
- Web 在线文件管理器学习笔记与总结(19)上传文件
dir.func.php 中添加方法: /* 上传文件 */ function uploadFile($fileInfo,$path,$allowExt = array('jpg','jpeg','p ...
- 基于vue+springboot+docker网站搭建【二】搞定服务器
搞定服务器 双11在阿里云用家人的身份证注册账号,买了两台打折的服务器.2核4G一台3年799块:1核2G一台3年229块.机器配置如下图. 1.买的时候注意相同地区的相同可用区.比如我两台机器都选择 ...
- SpringMVC 实现POI读取Excle文件中数据导入数据库(上传)、导出数据库中数据到Excle文件中(下载)
读取Excale表返回一个集合: package com.shiliu.game.utils; import java.io.File; import java.io.FileInputStream; ...
- 阿里云 云解析使用方法/在阿里云ESC服务器解析域名并绑定服务器IP后上传文件通过域名访问步骤教程
第一步:登录阿里云官网,获取服务器ECS的指定公网IP地址. 1.输入阿里云官网账号进入首页,如下图: 2.点击进入"管理控制台",如下图: 3.点击"云服务器ECS&q ...
- 风炫安全web安全学习第三十六节课-15种上传漏洞讲解(一)
风炫安全web安全学习第三十六节课 15种上传漏洞讲解(一) 文件上传漏洞 0x01 漏洞描述和原理 文件上传漏洞可以说是日常渗透测试用得最多的一个漏洞,因为用它获得服务器权限最快最直接.但是想真正把 ...
随机推荐
- Nginx实战系列之功能篇----后端节点健康检查(转)
公司前一段对业务线上的nginx做了整理,重点就是对nginx上负载均衡器的后端节点做健康检查.目前,nginx对后端节点健康检查的方式主要有3种,这里列出: 1.ngx_http_proxy_m ...
- Node.js Streams:你需要知道的一切
Node.js Streams:你需要知道的一切 图像来源 Node.js流以难以使用而闻名,甚至更难理解.好吧,我有个好消息 - 不再是这样了. 多年来,开发人员在那里创建了许多软件包,其唯一目的是 ...
- 将sqlServer上的数据库文件进行盘目的迁移
在数据库客户端创建数据库时要改为.mdf文件,因为附加问价时附加的是.mdf文件: 在里选中相应的数据库 右键->任务-分离 在 剪切到相应的想放置的盘目. 例如迁移到E盘下: 在数据库-> ...
- 关于Cocos2d-x中掉帧导致游戏一卡一卡的网上一些的解决方法
方法1 掉帧主要是setpostion引起的 因为每一帧每一个精灵都要set一次虽然不知道为什么会这样但是if(poX<1000&&pox>-100){ xx-& ...
- VC dimension(Vapnik-Chervonenkis dimension)
二维平面的线性分类器的VC维讨论:http://www.tuicool.com/articles/JjaMfe VC维介绍:http://blog.csdn.net/lucylove3943/arti ...
- Spring RestTemplate 小结
关于RestTemplate 首先,你可以把它理解为一个发起请求并接收响应的工具类(功能类似浏览器). 其次,它其实是一个壳,具体还是通过调用别的接口来实现(如jdk自带的连接,或者HttpClien ...
- AOP(Aspect Oriented Programming),即面向切面编程
AOP AOP(Aspect Oriented Programming),即面向切面编程,可以说是OOP(Object Oriented Programming,面向对象编程)的补充和完善.OOP引入 ...
- 什么是Apache ZooKeeper?
Apache ZooKeeper是由集群(节点组)使用的一种服务,用于在自身之间协调,并通过稳健的同步技术维护共享数据.ZooKeeper本身是一个分布式应用程序,为写入分布式应用程序提供服务. Zo ...
- 帝国cms的list.var中使用php函数
$r[title] = esub($r[title],8,'...'); //截取前8个字符,多出部分用...代替 $r[title] = str_replace("lhj",&q ...
- 【转】IIS日志-网站运维的好帮手
对于一个需要长期维护的网站来说,如何让网站长久稳定运行是件很有意义的事情. 有些在开发阶段没有暴露的问题很有可能就在运维阶段出现了,这也是很正常的. 还有些时候,我们希望不断地优化网站,让网站更快速的 ...