关于go:go-hack五使用go-rpc和metasploit联动

50次阅读

共计 2860 个字符,预计需要花费 8 分钟才能阅读完成。

go 网络安全代码地址

筹备工作

  1. 开启 metasploit 的 rpc 通信

    • kali 中 msfconsole 进入交互模式
    • load msgrpc Pass=123 Serverhost=0.0.0.0 开启 rpc
  2. metasploit 应用 messagePack 进行通信,

    • go get gopkg.in/vmihailenco/msgpack.v2 应用第三方的 messagepack 包

基础知识

  1. metaploit api
  2. flag \`msgpack:”,asArray”\` \`msgpck:”,omitempty”\`
  3. msgpack 强制为索引数组 _msgpack struct{} \`msgpack:”,asArray”\`
package rpc
import (
"bytes"
"fmt"
"log"
"net/http"
"gopkg.in/vmihailenco/msgpack.v2"
)
// sessionlist 申请的构造体
type SessionListReq struct {_msgpack struct{} `msgpack:",asArray"` // 当做索引数组解析
Method string
Token string
}
// sessionList 的响应
type SessionListRes struct {
ID uint32 `msgpack:",omitempty"` // 可选参数
Type string `msgpack:"type"`
TunnelLocal string `msgpack:"tunnel_local"`
TunnelPeer string `msgpack:"tunnel_peer"`
ViaExploit string `msgpack:"via_exploit"`
ViaPayload string `msgpack:"via_payload"`
Desc string `msgpack:"desc"`
Info string `msgpack:"info"`
Workspace string `msgpack:"workspack"`
SessionHost string `msgpack:"session_host"`
SessionPort int `msgpack:"session_port"`
Username string `msgpack:"username"`
UUID string `msgpack:"uuid"`
ExploitUUID string `msgpack:"exploit_uuid"`
}
// 登录申请
type loginReq struct {_msgpack struct{} `msgpack:",asArray"`
Method string
Username string
Pass string
}
// 登录返回
type loginRes struct {
Result string `msgpack:"result"`
Token string `msgpack:"token"`
Error bool `msgpack:"error"`
ErrorClass string `msgpack:"error_class"`
ErrorMessage string `msgpack:"error_message"`
}
// 登出申请
type logoutReq struct {_msgpack struct{} `msgpack:",asArray"`
Method string
Token string
LogoutToken string
}
// 登出响应
type logoutRes struct {Result string `msgpack:"result"`}
// 通用信息
type Msf struct {
host string
user string
pass string
token string
}
// 初始化
func New(host, user, pass string) (*Msf, error) {
rtn := &Msf{
host: host,
user: user,
pass: pass,
}
if err := rtn.Login(); err != nil {return nil, err}
return rtn, nil
}
func (msf *Msf) send(req interface{}, res interface{}) error {buf := new(bytes.Buffer) //https://blog.csdn.net/flyfreelyit/article/details/80291945 bytes.Buffer 应用
// encodereq 放到 buf 中
msgpack.NewEncoder(buf).Encode(req)
dst := fmt.Sprintf("http://%s/api", msf.host)
resp, err := http.Post(dst, "binary/message-pack", buf)
if err != nil {log.Printf("%s", err)
return err
}
defer resp.Body.Close()
if err = msgpack.NewDecoder(resp.Body).Decode(res); err != nil {log.Printf("%s", err)
return err
}
fmt.Println(res)
return nil
}
func (msf *Msf) Login() error {
ctx := &loginReq{
Method: "auth.login",
Username: msf.user,
Pass: msf.pass,
}
var res loginRes
// send 的第二个参数为 interface 能够接管任何类型
if err := msf.send(ctx, &res); err != nil {log.Printf("%s", err)
return err
}
msf.token = res.Token
return nil
}
func (msf *Msf) Logout() error {
ctx := &logoutReq{
Method: "auth.logout",
Token: msf.token,
LogoutToken: msf.token,
}
var res logoutRes
if err := msf.send(ctx, &res); err != nil {log.Println(err)
return err
}
msf.token = ""
return nil
}
func (msf *Msf) SessionList() (map[uint32]SessionListRes, error) {
req := &SessionListReq{
Method: "session.list",
Token: msf.token,
}
res := make(map[uint32]SessionListRes)
if err := msf.send(req, &res); err != nil {log.Fatal(err)
return nil, err
}
for id, session := range res {
session.ID = id
res[id] = session
}
return res, nil
}

正文完
 0