snmp wireshark 抓包

背景

看完rfc 上 snmp v1协议,还是一脸懵逼,于是想通过抓包来查看snmp发送的数据。

1 客户端 使用 iReasoning MIB browse

最开始看到这里提到了 iReasoning MIB browse handbook.fortinet.com.cn/%E7%B3%BB%E...

下载地址 www.ireasoning.com/download.sh... 下载MIB Browser Free Personal Edition 也够用了 界面如下所示

2 ubuntu 下 snmp安装

一开始搜到的是如下的文章 handbook.fortinet.com.cn/%E7%B3%BB%E... 里面是针对centos配置的,就跳过了。。

ubuntu开始参考了如下的文档 supportportal.juniper.net/s/article/W...

arduino 复制代码
sudo apt-get install snmpd

但是看起来后面的mibs配置麻烦,又参考了下面的文档 askubuntu.com/questions/1...

sql 复制代码
sudo apt-get update
sudo apt-get install snmpd
sudo nano /etc/snmp/snmpd.conf

"#agentAddress udp:127.0.0.1:161"
"agentAddress udp:161,udp6:[::1]:161"

sudo service snmpd restart

Step 2:

sudo apt-get install snmp-mibs-downloader
sudo download-mibs

sudo nano /etc/snmp/snmp.conf
mibs +ALL

ps:我没装nano,上面的我使用了vim

客户端安装这个没啥

复制代码
sudo apt install snmp

3 window 下 net-snmp安装

3.1 直接使用系统进行安装

搜 应用和功能,点击 可选功能,之后 添加可选功能,输入snmp就能 安装

PS:我的系统禁止了更新,这里会报错。。。安装正常的可以忽略

0x80070422错误代码如何解决 www.php.cn/faq/533984....

3.2 使用二进制安装包

下载二进制包

net-snmp下载页面 www.net-snmp.org/download.ht...

这里使用了 "Sourceforge download page - all files" 来下载 sourceforge.net/projects/ne...

然后下载了net-snmp-5.5.0-2.x64.exe

官方的README里有一堆配置,没尝试(其中snmpconf依赖32位的Perl,放弃了)

bash 复制代码
  The Net-SNMP Windows installer package performs the following tasks:

  - Installs the Net-SNMP binaries, MIB files and ActiveState 5.8.x Perl PPM 
    package into the installation folder (defaults to c:\usr). 
  - Adds (install folder)\bin to the system PATH. 
  - Adds the following registry keys:
    - HKEY_LOCAL_MACHINE\Software\Net-SNMP\SNMPCONFPATH=(install folder)/etc/snmp;
      (install folder)/snmp/persist
    - HKEY_LOCAL_MACHINE\Software\Net-SNMP\SNMPSHAREPATH=(install folder)/share/snmp
  - Creates an snmp.conf file in SNMPCONFPATH which defines: 
    - mibdirs (install folder)/share/snmp/mibs 
    - persistentDir (install folder)/snmp/persist 
    - tempFilePattern (install folder)/temp/snmpdXXXXXX 

  After installing using the setup wizard, perform a quick test to verify that 
  Net-SNMP was installed correctly.  Run the following from a command prompt:

修改配置文件

C:\usr\etc\snmp\snmpd.conf 新建一个配置文件,内容如下

csharp 复制代码
# 设置只读社区名称(例如 public)
rocommunity public
# 允许所有IP访问(生产环境建议限制IP)
agentAddress udp:0.0.0.0:161

打开控制台启动

复制代码
snmpd

4 使用 iReasoning MIB browse 模拟请求

复制代码
需要启动 snmpd

地址选择localhost,mib 选择一个,然后操作选择 get,最后点 go

5 wireshark 抓取snmp

5.1 安装wireshark

下载页面 www.wireshark.org/download.ht...

5.2 选择网卡

我这里用了无线网卡 WLAN,还有一个loopback的网络,这里选择 "Adapter for loopback xxxx",抓取本地包就行

进入后,使用在过滤器中使用snmp协议进行过滤 如下所示

ini 复制代码
_ws.col.protocol == "SNMP"

5.3 再次尝试发送get请求

iReasoning MIB browse 如下所示

wireshark中如下所示

这里点左下角的snmp协议就能看到发送的字节 snmp版本 -1, 这里的0就是 v1

相关推荐
t***5447 小时前
Clang 编译器在 Orwell Dev-C++ 中的局限性
开发语言·c++
yolo_guo9 小时前
redis++使用: hmset 与 hmget
c++·redis
handler019 小时前
拒绝权限报错!三分钟掌握 Linux 权限管理
linux·c语言·c++·笔记·学习
t***54410 小时前
如何在Dev-C++中选择Clang编译器
开发语言·c++
汉克老师11 小时前
GESP2023年9月认证C++三级( 第一部分选择题(9-15))
c++·gesp三级·gesp3级
Wave84514 小时前
C++继承详解
开发语言·c++·算法
Tairitsu_H14 小时前
C++类基础概念:定义、实例化和this指针
开发语言·c++
不想写代码的星星14 小时前
C++17 string_view 观察报告:好用,但有点费命
c++
努力努力再努力wz14 小时前
【Linux网络系列】深入理解 I/O 多路复用:从 select 痛点到 poll 高并发服务器落地,基于 Poll、智能指针与非阻塞 I/O与线程池手写一个高性能 HTTP 服务器!(附源码)
java·linux·运维·服务器·c语言·c++·python
努力努力再努力wz14 小时前
【Linux网络系列】万字硬核解析网络层核心:IP协议到IP 分片重组、NAT技术及 RIP/OSPF 动态路由全景
java·linux·运维·服务器·数据结构·c++·python