SNMP TRAP发包工具

导语

日志审计系统需要具备多种采集方式,其中SNMP TRAP就是其中的主流,随着互联网快速发展,安全产品、网络产品等等产品层出不穷,日志审计系统所需要解析的产品种类也逐级增加,日志样本多样性成为了解析日志产品的痛点,之前分享了syslog方式发送数据包,这次将分享SNMP TRAP方式的发包工具。

工具功能描述

本工具通过SNMP TRAP 实现数据包发送,工具可以自定义接收端IP、端口,并且工具默认将使用者电脑IP作为发生端IP,支持自定义团体字、OID,因为在日常中SNMP TRAP发送可能会有多个OID,所以为了满足数据的多样性,工具提供了额外OID及VALUE的配置。

自定义执行次数,该参数决定任务的重复次数。

工具提供了两个SNMP版本的方式,分别为SNMP V1和SNMP V2。
自定义发送速率,默认值为1,工具在发送时将根据任务中的该参数进行每秒N次的发送。

工具提供了三种日志来源方式,分别为 单条自定义日志发送、日志文件读取发送、文件夹所有文件读取发送,基本满足了所有形式的样本读取。

工具提供任务列表,可以添加多个任务,任务执行时状态将显示运行中,执行完成将显示空闲,为满足使用者多种测试场景,多任务执行互不干扰,且左键单击每条任务均可进行指定任务的停止、启动、删除动作。

为方便使用者记录、查看当前程序运行情况及执行历史,工具提供了执行日志展示栏,日志栏内容支持复制、清除。

工具截图

在这里插入图片描述
例:上图中OID为【1.3.6.1.4.1.8886.2.3.1.1.1.2.2】额外OID和VALUE为【1.3.6.1.4.1.8886.2.3.1.1.1.2.1和pysnmp_test】,原文为【Nov 8 16:38:13 localhost sshd[1089535]: pam_unix(sshd:session): session closed for user root】,通过工具发送最终可以得到日志:【{1.3.6.1.4.1.8886.2.3.1.1.1.2.1=pysnmp_test, 1.3.6.1.4.1.8886.2.3.1.1.1.2.2=Nov 8 16:38:13 localhost sshd[1089535]: pam_unix(sshd:session): session closed for user root}】

工具实现原理

工具以Python3.7为基础语言,主要引入Pyqt5(界面构建)及pysnmp(发包实现)两个模块,通过界面配置将任务数据进行存储在缓存种,并加入到任务List中。

在多任务执行时会将该任务线程加入到线程池中,为保证使用者电脑资源不被过度试用,线程池默认限制为10个,任务被执行配置数据会再次读档,重复函数默认1秒执行一次,重复函数将任务信息总结,传递给pysnmp模块,该模块会将日志整合并发送,代码实现可见下方图片,随后将通过自定义重复函数进行任务的执行。

任务执行或配置错误的信息将详细的展示在日志区域,日志有标识符如 任务1、任务2,可以根据前端的标识与列表的任务相匹配,避免了日志多分类不清楚的问题。

部分实现代码摘抄

对鼠标左键进行绑定
在这里插入图片描述
自定义执行函数
在这里插入图片描述
Pysnmp发送数据
在这里插入图片描述

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java SNMP Trap是一种用于网络管理的协议,它允许网络设备向网络管理系统发送事件通知。SNMP(Simple Network Management Protocol)是一种用于管理和监控网络设备的标准协议。 在Java中,你可以使用第三方库来实现SNMP Trap的功能,比如SNMP4J。SNMP4J是一个开源的Java库,提供了丰富的API来实现SNMP协议的各种功能,包括发送和接收SNMP Trap。 要使用SNMP4J发送SNMP Trap,你需要以下步骤: 1. 创建一个SNMP Trap发送器对象。 2. 设置目标主机的IP地址和端口号。 3. 创建一个SNMP Trap消息对象,并设置相关属性,如版本号、社区名、通知类型等。 4. 发送SNMP Trap消息。 以下是一个简单的示例代码,演示了如何使用SNMP4J发送SNMP Trap: ```java import org.snmp4j.CommunityTarget; import org.snmp4j.PDU; import org.snmp4j.Snmp; import org.snmp4j.TransportMapping; import org.snmp4j.event.ResponseEvent; import org.snmp4j.mp.SnmpConstants; import org.snmp4j.smi.Address; import org.snmp4j.smi.GenericAddress; import org.snmp4j.smi.OID; import org.snmp4j.smi.OctetString; import org.snmp4j.smi.UdpAddress; import org.snmp4j.smi.VariableBinding; import org.snmp4j.transport.DefaultUdpTransportMapping; public class SNMPTrapSender { public static void main(String[] args) throws Exception { // 设置目标主机的IP地址和端口号 Address targetAddress = GenericAddress.parse("udp:127.0.0.1/162"); // 创建一个SNMP Trap发送器对象 TransportMapping<?> transport = new DefaultUdpTransportMapping(); Snmp snmp = new Snmp(transport); transport.listen(); // 创建一个SNMP Trap消息对象 PDU pdu = new PDU(); pdu.setType(PDU.TRAP); // 设置通知类型为通用陷阱 pdu.add(new VariableBinding(SnmpConstants.sysUpTime, new OctetString("0"))); pdu.add(new VariableBinding(SnmpConstants.snmpTrapOID, new OID("1.3.6.1.4.1.12345.1"))); pdu.add(new VariableBinding(SnmpConstants.snmpTrapAddress, new UdpAddress("127.0.0.1/162"))); pdu.add(new VariableBinding(new OID("1.3.6.1.2.1.1.1.0"), new OctetString("Test trap"))); // 发送SNMP Trap消息 CommunityTarget target = new CommunityTarget(); target.setCommunity(new OctetString("public")); target.setAddress(targetAddress); target.setVersion(SnmpConstants.version2c); ResponseEvent response = snmp.send(pdu, target); System.out.println("SNMP Trap sent successfully"); // 关闭SNMP连接 snmp.close(); } } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值