2017-03-13 97 views
2

我正在努力从过去的几天发送SNMPV3陷阱使用身份验证和专用短语。问题是:在我收到带有Auth-Priv的第一个陷阱SNMPv3后,有时(约2分钟)后我无法收到陷阱。接收者就像忽略了即将到来的每一个陷阱。第一次发送后无法接收SNMPv3陷阱几次。 [snmp4j-Java]

这里是我的代码:

的Receiver.java

try { 
     // set udpAdress and transportMapping 
     final UdpAddress udpAddress = new UdpAddress(162); 
     final TransportMapping transportMapping = new   DefaultUdpTransportMapping(udpAddress); 

     // Protocole de sécurité +usm +snmp 
     this.snmp = new Snmp(new MessageDispatcherImpl(), transportMapping); 
     SecurityProtocols.getInstance().addDefaultProtocols(); 
     final USM usm = new USM(SecurityProtocols.getInstance(), 
      new OctetString(MPv3.createLocalEngineID(new OctetString())), 
      0); 
     SecurityProtocols.getInstance().addPrivacyProtocol(new PrivDES()); 
     usm.setEngineDiscoveryEnabled(true); 

     // Add the MPv 
     snmp.getMessageDispatcher().addMessageProcessingModel(new MPv1()); 
     snmp.getMessageDispatcher().addMessageProcessingModel(new MPv2c()); 
     snmp.getMessageDispatcher().addMessageProcessingModel(new MPv3(usm)); 

     // Security model 
     SecurityModels.getInstance().addSecurityModel(usm); 

     // Add user 
     snmp.getUSM().addUser(new OctetString("v3AuthSHAPrivDESSecName"), 
      new UsmUser(new OctetString("v3AuthSHAPrivDESSecName"), AuthMD5.ID, 
       new OctetString("v3AuthSHAPrivDESAuthPassword"), PrivDES.ID, 
       new OctetString("v3AuthSHAPrivDESPrivPassword"))); 

     // Launch of the listener 
     this.snmp.addCommandResponder(this); 
     snmp.listen();` 

的Sender.java

try { 
     // set udpAdress and transportMapping 
     Address targetAddress = GenericAddress.parse("udp:" + ipAddress + "/" + port); 
     TransportMapping transport = new DefaultUdpTransportMapping(); 
     Snmp snmp = new Snmp(transport); 

     // Protocole de sécurité +usm +snmp 
     SecurityProtocols.getInstance().addDefaultProtocols(); 
     final USM usm = new USM(SecurityProtocols.getInstance(), 
      new OctetString(MPv3.createLocalEngineID(new OctetString())), 
      0); 

     SecurityProtocols.getInstance().addPrivacyProtocol(new PrivDES()); 
     SecurityModels.getInstance().addSecurityModel(usm); 

     transport.listen(); 

     // Ajout d'un user avec les paramètres de sécurité 
     snmp.getUSM().addUser(new OctetString("v3AuthSHAPrivDESSecName"), 
      new UsmUser(new OctetString("v3AuthSHAPrivDESSecName"), AuthMD5.ID, 
       new OctetString("v3AuthSHAPrivDESAuthPassword"), PrivDES.ID, 
       new OctetString("v3AuthSHAPrivDESPrivPassword"))); 

     // Create Target 
     UserTarget target = new UserTarget(); 
     target.setAddress(targetAddress); 
     target.setRetries(1111); 
     target.setTimeout(11111500); 
     target.setVersion(SnmpConstants.version3); 
     target.setSecurityLevel(SecurityLevel.AUTH_PRIV); 
     target.setSecurityName(new OctetString("v3AuthSHAPrivDESSecName")); 

     // Create PDU 1 for V3 
     ScopedPDU pdu = new ScopedPDU(); 
     pdu.setType(PDU.TRAP); 
     pdu.add(new VariableBinding(SnmpConstants.sysUpTime)); 
     pdu.add(new VariableBinding(SnmpConstants.snmpTrapOID, SnmpConstants.linkDown)); 
     pdu.add(new VariableBinding(new OID(trapOid), new OctetString("V33333"))); 
     snmp.send(pdu, target); 

     System.out.println("Sending Trap to (IP:Port)=> " + ipAddress + ":" + port); 

     snmp.addCommandResponder(new CommandResponder() { 
      public void processPdu(CommandResponderEvent arg0) { 
       System.out.println(arg0); 
      } 
     }); 
     snmp.close(); 
  • 我使用的SNMP4J-1.1依赖。我不知道为什么它忽略了第一次发送后2分钟左右出现的陷阱。

    非常感谢朋友们的帮助

+0

朋友你好,我添加一些编辑在我的问题,speciellay“斐伊川的朋友:)”,但它没有把我的编辑X), 预先感谢您的帮助和想法,大起来 –

回答

0

我找到了答案! :D只需将依赖关系改为snmp4j-2。*就可以了,现在我用了snmp4j-2.5.0。它的工作完美,如果你想使用它,上面的代码工作完美。

有一个愉快的一天代码:-)