Jump to content

Metasploit Server Module


Recommended Posts

Hey all, I am trying to develop a metasploit module that acts as a server.  I need the module to accept a request, send a payload, accept a second request, and send a second response.  The problem that I am running into is all of the modules I am finding just do 1 exchange in a fire-and-forget format.

My current code takes every request as a separate connection and closes after 1 exchange.  Any idea how I can accomplish this?


Here is what I have so far:

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

  include Msf::Exploit::Remote::HttpServer
  def initialize(info = {})
        'Name'           => 'Test',
        'Description'    => %q(
            test desc.
        'License'        => MSF_LICENSE,
        'Author'         => ['me'],
        'Targets'        =>
                'Platform' => 'linux'
        OptString.new('SRVHOST', [false, 'The local host to listen on.  This must be an address on the local machine or', '']),
        OptString.new('SRVPORT', [false, 'The local port to listen on', '80']),
        OptString.new('URIPATH', [false, 'The URI to use', 'test_file']),
    deregister_options('SSL', 'SSLCert')

  def on_request_uri(cli, request)
    if some_condition
      response = create_response(200)
      response = create_response(404)


Link to comment
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

  • Recently Browsing   0 members

    • No registered users viewing this page.
  • Create New...