最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

Python实现远程调用MetaSploit的方法

来源:动视网 责编:小采 时间:2020-11-27 14:38:14
文档

Python实现远程调用MetaSploit的方法

Python实现远程调用MetaSploit的方法:本文较为详细的讲述了Python实现远程调用MetaSploit的方法,对Python的学习来说有很好的参考价值。具体实现方法如下: (1)安装Python的msgpack类库,MSF官方文档中的数据序列化标准就是参照msgpack。 root@kali:~# apt-get ins
推荐度:
导读Python实现远程调用MetaSploit的方法:本文较为详细的讲述了Python实现远程调用MetaSploit的方法,对Python的学习来说有很好的参考价值。具体实现方法如下: (1)安装Python的msgpack类库,MSF官方文档中的数据序列化标准就是参照msgpack。 root@kali:~# apt-get ins


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

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

root@kali:~# apt-get install python-setuptools
root@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 start
root@kali:~# sudo -u postgres /usr/bin/psql < createdb_sql.txt


(4)创建setup.rc文件

db_connect msf:msf123@127.0.0.1/msf
load 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 msfrpc
root@kali:~# cd msfrpc/python-msfrpc
root@kali:~# python setup.py install

测试代码如下:

#!/usr/bin/env python
import msgpack
import 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
" % 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 "	%s" % i

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

文档

Python实现远程调用MetaSploit的方法

Python实现远程调用MetaSploit的方法:本文较为详细的讲述了Python实现远程调用MetaSploit的方法,对Python的学习来说有很好的参考价值。具体实现方法如下: (1)安装Python的msgpack类库,MSF官方文档中的数据序列化标准就是参照msgpack。 root@kali:~# apt-get ins
推荐度:
标签: 远程 调用 python
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top