香港云主机最佳企业级服务商!

ADSL拨号VPS包含了中国大陆(联通,移动,电信,)

中国香港,国外拨号VPS。

当前位置:云主机 > python >

电信ADSL拨号VPS
联通ADSL拨号VPS
移动ADSL拨号VPS

Python实现远程调用MetaSploit的方法


时间:2021-04-29 10:48 作者:admin610456


本文较为详细的讲述了python/' target='_blank'>python实现远程调用MetaSploit的方法,对Python的学习来说有很好的参考价值。具体实现方法如下:

(1)安装Python的msgpack类库,MSF官方文档中的数据序列化标准就是参照msgpack。

root@kali:~# apt-get install python-setuptoolsroot@kali:~# easy_install msgpack-python


(2)创建createdb_sql.txt:

create database msf;create user msf with password 'msf123';grant all privileges on database msf to msf;


(3)在PostgreSQL 执行上述文件:

root@kali:~# /etc/init.d/postgresql startroot@kali:~# sudo -u postgres /usr/bin/psql < createdb_sql.txt


(4)创建setup.rc文件

db_connect msf:msf123@127.0.0.1/msfload msgrpc User=msf Pass='abc123'


(5)启动MSF并执行载入文件

root@kali:~# msfconsole -r setup.rc* SNIP *[*] Processing setup.rc for ERB directives.resource (setup.rc)> db_connect msf:msf123@127.0.0.1/msf[*] Rebuilding the module cache in the background...resource (setup.rc)> load msgrpc User=msf Pass='abc123'[*] MSGRPC Service: 127.0.0.1:55552[*] MSGRPC Username: msf[*] MSGRPC Password: abc123[*] Successfully loaded plugin: msgrpc


(6)Github上有一个Python的类库,不过很不好用

root@kali:~# git clone git://github.com/SpiderLabs/msfrpc.git msfrpcroot@kali:~# cd msfrpc/python-msfrpcroot@kali:~# python setup.py install

测试代码如下:

#!/usr/bin/env pythonimport msgpackimport httplib class Msfrpc: class MsfError(Exception):  def __init__(self,msg):   self.msg = msg  def __str__(self):   return repr(self.msg)  class MsfAuthError(MsfError):  def __init__(self,msg):   self.msg = msg   def __init__(self,opts=[]):  self.host = opts.get('host') or "127.0.0.1"  self.port = opts.get('port') or 55552  self.uri = opts.get('uri') or "/api/"  self.ssl = opts.get('ssl') or False  self.authenticated = False  self.token = False  self.headers = {"Content-type" : "binary/message-pack" }  if self.ssl:   self.client = httplib.HTTPSConnection(self.host,self.port)  else:   self.client = httplib.HTTPConnection(self.host,self.port)  def encode(self,data):  return msgpack.packb(data) def decode(self,data):  return msgpack.unpackb(data)  def call(self,meth,opts = []):  if meth != "auth.login":   if not self.authenticated:    raise self.MsfAuthError("MsfRPC: Not Authenticated")   if meth != "auth.login":   opts.insert(0,self.token)   opts.insert(0,meth)  params = self.encode(opts)  self.client.request("POST",self.uri,params,self.headers)  resp = self.client.getresponse()  return self.decode(resp.read())   def login(self,user,password):  ret = self.call('auth.login',[user,password])  if ret.get('result') == 'success':self.authenticated = True    self.token = ret.get('token')    return True  else:    raise self.MsfAuthError("MsfRPC: Authentication failed") if __name__ == '__main__':  # Create a new instance of the Msfrpc client with the default options client = Msfrpc({})  # Login to the msfmsg server using the password "abc123" client.login('msf','abc123')  # Get a list of the exploits from the server mod = client.call('module.exploits')  # Grab the first item from the modules value of the returned dict print "Compatible payloads for : %s\n" % mod['modules'][0]  # Get the list of compatible payloads for the first option ret = client.call('module.compatible_payloads',[mod['modules'][0]]) for i in (ret.get('payloads')):  print "\t%s" % i

相信本文所述方法对大家的Python学习可以起到一定的学习借鉴作用。

(责任编辑:admin)






帮助中心
会员注册
找回密码
新闻中心
快捷通道
域名登录面板
虚机登录面板
云主机登录面板
关于我们
关于我们
联系我们
联系方式

售前咨询:17830004266(重庆移动)

企业QQ:383546523

《中华人民共和国工业和信息化部》 编号:ICP备00012341号

Copyright © 2002 -2018 香港云主机 版权所有
声明:香港云主机品牌标志、品牌吉祥物均已注册商标,版权所有,窃用必究

云官方微信

在线客服

  • 企业QQ: 点击这里给我发消息
  • 技术支持:383546523

  • 公司总台电话:17830004266(重庆移动)
  • 售前咨询热线:17830004266(重庆移动)