热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

记一次Nginx解析漏洞复现文件类型后门测试

Dowhatyousaid,saywhatyoucando

Do what you said,say what you can do

做你说过的,说你能做的


目录

    1.什么是解析漏洞

    2.在没有解析漏洞的网站上传文件后门

    3.在存在解析漏洞的Nginx服务器上上传文件后门

    4.总结

 

1.什么是解析漏洞?

     解析漏洞是指服务器应用程序在解析某些精心构造的后缀文件时,会将其解析成网页脚本,从而导致网站沦陷的一种漏洞。

 

2.在没有解析漏洞的网站上传文件后门

    (1)工具:phpstudy、火狐浏览器、notepad++                

    (2)目的:演示在本地站点创建一个带有后门代码的文件,该文件是不会被网站服务器应用程序成功解析的。

    (3)演示步骤:

            1.在phpstudy的网站根目录下创建一个名为“test111.php”的文件,内容如下:

               注:phpinfo()是php的内置函数,用于查看php的一些配置信息

 

           2.在浏览器中访问该文件,能正常显示:

          3.将“test111.php”改为“test111.jpg”

              

          4.在浏览器中访问该文件,发现不能正常显示:

              在URL末尾加上“/.php”后缀,图片并未被解析成php文件:

 

3.在存在解析漏洞的Nginx服务器上上传文件后门

    (1)工具:vulhub漏洞平台、phpstudy、ubuntu 操作系统、VM虚拟机、火狐浏览器、Notepad++

                        在使用工具前,先介绍一下vulhub吧,vulhub是一款基于docker和docker-compose的漏洞环境部署平台,在VM虚拟机中使用ubuntu来搭建vulhub漏洞环境。

                        其中的docker是一个开源的应用容器引擎,docker-compose是用python写的一个一个docker容器管理工具。

                        关于vulhub漏洞环境平台的相关漏洞利用等知识可以参考链接:https://vulhub.org/

     (2)演示过程:

              注:关于vulhub的安装和使用教程在网上都能搜到,这里就不细讲。

              1.开启虚拟机,找到文件“nginx_parsing_vulnerability”

              2.按照下面的顺序启动靶场环境:

                 编译:sudo docker-compose build

                启动:sudo docker-compose up -d

              3.查看靶场ip,并在真机中访问:

                找到ens33中的 inet,这个就是靶场环境的ip,复制下来,在真机中访问:

              4.在百度上随意找一张图片,用Notepad++打开,在末尾加上,可以多加几次,以防执行失败,修改完成后直接保存,不用改后缀。

              5.将修改好的图片上传到靶场,点击提交查询:

                结果显示上传成功!

              6.复制路径后访问图片:

              7.在URL末尾增加“/.php”后缀后,该图片被解析为php文件:

                如果插入的是一句话木马,就能实现获取网站webshell等目的了。

 

4.总结

  上文第2点首先举例说明在不能存在解析漏洞的情况下上传一个具有后门代码的文件,并不会被网站服务器解析为脚本文件,而第3点印证了存在解析漏洞的情况下上传后门文件是会被网站服务器解析成脚本文件的。

  在第3点中加入能正常执行,说明只要在图片文件中插入的是一句话木马,同样也会被网站服务器成功解析,这时候配合使用菜刀等工具就能成功拿到目标站点的webshell。


推荐阅读
  • 如何实现织梦DedeCms全站伪静态
    本文介绍了如何通过修改织梦DedeCms源代码来实现全站伪静态,以提高管理和SEO效果。全站伪静态可以避免重复URL的问题,同时通过使用mod_rewrite伪静态模块和.htaccess正则表达式,可以更好地适应搜索引擎的需求。文章还提到了一些相关的技术和工具,如Ubuntu、qt编程、tomcat端口、爬虫、php request根目录等。 ... [详细]
  • 31.项目部署
    目录1一些概念1.1项目部署1.2WSGI1.3uWSGI1.4Nginx2安装环境与迁移项目2.1项目内容2.2项目配置2.2.1DEBUG2.2.2STAT ... [详细]
  • 树莓派语音控制的配置方法和步骤
    本文介绍了在树莓派上实现语音控制的配置方法和步骤。首先感谢博主Eoman的帮助,文章参考了他的内容。树莓派的配置需要通过sudo raspi-config进行,然后使用Eoman的控制方法,即安装wiringPi库并编写控制引脚的脚本。具体的安装步骤和脚本编写方法在文章中详细介绍。 ... [详细]
  • 本文介绍了Python高级网络编程及TCP/IP协议簇的OSI七层模型。首先简单介绍了七层模型的各层及其封装解封装过程。然后讨论了程序开发中涉及到的网络通信内容,主要包括TCP协议、UDP协议和IPV4协议。最后还介绍了socket编程、聊天socket实现、远程执行命令、上传文件、socketserver及其源码分析等相关内容。 ... [详细]
  • 本文介绍了在Python3中如何使用选择文件对话框的格式打开和保存图片的方法。通过使用tkinter库中的filedialog模块的asksaveasfilename和askopenfilename函数,可以方便地选择要打开或保存的图片文件,并进行相关操作。具体的代码示例和操作步骤也被提供。 ... [详细]
  • 搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的详细步骤
    本文详细介绍了搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的步骤,包括环境说明、相关软件下载的地址以及所需的插件下载地址。 ... [详细]
  • mac php错误日志配置方法及错误级别修改
    本文介绍了在mac环境下配置php错误日志的方法,包括修改php.ini文件和httpd.conf文件的操作步骤。同时还介绍了如何修改错误级别,以及相应的错误级别参考链接。 ... [详细]
  • 一句话解决高并发的核心原则
    本文介绍了解决高并发的核心原则,即将用户访问请求尽量往前推,避免访问CDN、静态服务器、动态服务器、数据库和存储,从而实现高性能、高并发、高可扩展的网站架构。同时提到了Google的成功案例,以及适用于千万级别PV站和亿级PV网站的架构层次。 ... [详细]
  • 如何提高PHP编程技能及推荐高级教程
    本文介绍了如何提高PHP编程技能的方法,推荐了一些高级教程。学习任何一种编程语言都需要长期的坚持和不懈的努力,本文提醒读者要有足够的耐心和时间投入。通过实践操作学习,可以更好地理解和掌握PHP语言的特异性,特别是单引号和双引号的用法。同时,本文也指出了只走马观花看整体而不深入学习的学习方式无法真正掌握这门语言,建议读者要从整体来考虑局部,培养大局观。最后,本文提醒读者完成一个像模像样的网站需要付出更多的努力和实践。 ... [详细]
  • 解决php错误信息不显示在浏览器上的方法
    本文介绍了解决php错误信息不显示在浏览器上的方法。作者发现php中的各种错误信息并不显示在浏览器上,而是需要在日志文件中查看。为了解决这个问题,作者提供了一种解决方式:通过修改php.ini文件中的display_errors参数为On,并重启服务。这样就可以在浏览器上直接显示php错误信息了。 ... [详细]
  • 分享css中提升优先级属性!important的用法总结
    web前端|css教程css!importantweb前端-css教程本文分享css中提升优先级属性!important的用法总结微信门店展示源码,vscode如何管理站点,ubu ... [详细]
  • svnWebUI:一款现代化的svn服务端管理软件
    svnWebUI是一款图形化管理服务端Subversion的配置工具,适用于非程序员使用。它解决了svn用户和权限配置繁琐且不便的问题,提供了现代化的web界面,让svn服务端管理变得轻松。演示地址:http://svn.nginxwebui.cn:6060。 ... [详细]
  • 目录浏览漏洞与目录遍历漏洞的危害及修复方法
    本文讨论了目录浏览漏洞与目录遍历漏洞的危害,包括网站结构暴露、隐秘文件访问等。同时介绍了检测方法,如使用漏洞扫描器和搜索关键词。最后提供了针对常见中间件的修复方式,包括关闭目录浏览功能。对于保护网站安全具有一定的参考价值。 ... [详细]
  • Linux下部署Symfoy2对app/cache和app/logs目录的权限设置,symfoy2logs
    php教程|php手册xml文件php教程-php手册Linux下部署Symfoy2对appcache和applogs目录的权限设置,symfoy2logs黑色记事本源码,vsco ... [详细]
  • 计算机存储系统的层次结构及其优势
    本文介绍了计算机存储系统的层次结构,包括高速缓存、主存储器和辅助存储器三个层次。通过分层存储数据可以提高程序的执行效率。计算机存储系统的层次结构将各种不同存储容量、存取速度和价格的存储器有机组合成整体,形成可寻址存储空间比主存储器空间大得多的存储整体。由于辅助存储器容量大、价格低,使得整体存储系统的平均价格降低。同时,高速缓存的存取速度可以和CPU的工作速度相匹配,进一步提高程序执行效率。 ... [详细]
author-avatar
手机用户2502910651
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有