This commit is contained in:
insanity 2017-04-10 17:32:07 +09:00
commit 2f370b1a30
9 changed files with 436 additions and 0 deletions

29
pom.xml Normal file
View File

@ -0,0 +1,29 @@
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>com.loafle</groupId>
<artifactId>maven_parent_jar</artifactId>
<version>1.0.0-RELEASE</version>
</parent>
<groupId>com.loafle</groupId>
<artifactId>snmp_crawler</artifactId>
<packaging>jar</packaging>
<version>1.0.0-SNAPSHOT</version>
<name>com.loafle.snmp_crawler</name>
<dependencies>
<!-- https://mvnrepository.com/artifact/org.snmp4j/snmp4j -->
<dependency>
<groupId>org.snmp4j</groupId>
<artifactId>snmp4j</artifactId>
<version>2.5.0</version>
</dependency>
</dependencies>
</project>

23
snmp_crawler.iml Normal file
View File

@ -0,0 +1,23 @@
<?xml version="1.0" encoding="UTF-8"?>
<module org.jetbrains.idea.maven.project.MavenProjectsManager.isMavenModule="true" type="JAVA_MODULE" version="4">
<component name="NewModuleRootManager" LANGUAGE_LEVEL="JDK_1_8">
<output url="file://$MODULE_DIR$/target/classes" />
<output-test url="file://$MODULE_DIR$/target/test-classes" />
<content url="file://$MODULE_DIR$">
<sourceFolder url="file://$MODULE_DIR$/src/main/java" isTestSource="false" />
<sourceFolder url="file://$MODULE_DIR$/src/main/resources" type="java-resource" />
<sourceFolder url="file://$MODULE_DIR$/src/test/java" isTestSource="true" />
<sourceFolder url="file://$MODULE_DIR$/src/test/resources" type="java-test-resource" />
<excludeFolder url="file://$MODULE_DIR$/target" />
</content>
<orderEntry type="inheritedJdk" />
<orderEntry type="sourceFolder" forTests="false" />
<orderEntry type="library" name="Maven: org.snmp4j:snmp4j:2.5.0" level="project" />
<orderEntry type="library" name="Maven: log4j:log4j:1.2.14" level="project" />
<orderEntry type="library" scope="TEST" name="Maven: junit:junit:4.12" level="project" />
<orderEntry type="library" scope="TEST" name="Maven: org.hamcrest:hamcrest-core:1.3" level="project" />
<orderEntry type="library" name="Maven: org.slf4j:slf4j-api:1.7.13" level="project" />
<orderEntry type="library" scope="RUNTIME" name="Maven: ch.qos.logback:logback-classic:1.1.3" level="project" />
<orderEntry type="library" scope="RUNTIME" name="Maven: ch.qos.logback:logback-core:1.1.3" level="project" />
</component>
</module>

View File

@ -0,0 +1,71 @@
package com.loafle.crawler.snmp;
import java.util.Map;
/**
* Created by insanity on 17. 4. 10.
*/
public class Crawler {
//v2c
private static String addr = "192.168.1.215";
private static String port = "161";
private static String community = "public";
/**
* v3
* loafle MD5 "qwer5795" DES "qweqwe123" : AUTHPRIV
* loafle2 SHA "qwer5795" AES "qweqwe123" : AUTHPRIV
* loafle3 MD5 "qwer5795" : AUTHNOPRIV
* loafle4 :NOAUTHNOPRIV
*/
private static String user = "loafle3";
private static int authType = 1;
private static String authPass = "qwer5795";
private static int privType = 0;
private static String privPass = "qweqwe123";
public static void main(String[] args) {
useV2c();
useV3();
}
private static void useV2c() {
try {
SNMPv2c snmp = new SNMPv2c();
Map walkResult = snmp.walk(addr, port, community, "1.3.6.1.2.1.25.2.3.1.3");
printResult(walkResult);
Map getResult = snmp.get(addr, port, community, new String[]{"1.3.6.1.2.1.1.5.0", "1.3.6.1.2.1.2.2.1.6.2"});
printResult(getResult);
} catch (Exception e) {
System.err.println("An Exception happend as follows.");
System.err.println(e.getMessage());
e.printStackTrace();
}
}
private static void useV3() {
try {
SNMPv3 snmp = new SNMPv3();
Map walkResult = snmp.walk(addr, port, user, authType, authPass, privType, privPass, "1.3.6.1.2.1.25.2.3.1.3");
printResult(walkResult);
Map getResult = snmp.get(addr, port, user, authType, authPass, privType, privPass, new String[]{"1.3.6.1.2.1.1.5.0", "1.3.6.1.2.1.2.2.1.6.2"});
printResult(getResult);
} catch (Exception e) {
System.err.println("An Exception happend as follows.");
System.err.println(e.getMessage());
e.printStackTrace();
}
}
private static void printResult(Map<String, String> result) {
for (Map.Entry<String, String> entry : result.entrySet()) {
System.out.printf("key: %s - value: %s\n", entry.getKey(), entry.getValue());
}
}
}

View File

@ -0,0 +1,83 @@
package com.loafle.crawler.snmp;
import org.snmp4j.PDU;
import org.snmp4j.Snmp;
import org.snmp4j.Target;
import org.snmp4j.event.ResponseEvent;
import org.snmp4j.smi.OID;
import org.snmp4j.smi.VariableBinding;
import org.snmp4j.util.TreeEvent;
import org.snmp4j.util.TreeUtils;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
/**
* Created by insanity on 17. 4. 10.
*/
public abstract class SNMP {
protected Map<String, String> get(Snmp snmp, PDU pdu, Target target) throws Exception {
ResponseEvent response = snmp.get(pdu, target);
snmp.close();
if (response == null) {
throw new Exception("Error: No response from SNMP Agent.");
}
PDU responsePDU = response.getResponse();
if (responsePDU == null) {
throw new Exception("Error: Response PDU is null");
}
int errorStatus = responsePDU.getErrorStatus();
int errorIndex = responsePDU.getErrorIndex();
String errorStatusText = responsePDU.getErrorStatusText();
if (errorStatus != PDU.noError) {
throw new Exception("Error: " + errorIndex + " " + errorStatusText);
}
Map<String, String> result = new HashMap<String, String>();
for (VariableBinding varBinding : responsePDU.getVariableBindings()) {
if (varBinding == null) {
continue;
}
result.put(varBinding.getOid().toString(), varBinding.getVariable().toString());
}
return result;
}
protected Map<String, String> walk(Snmp snmp, String oidStr, Target target, TreeUtils treeUtils) throws Exception {
OID oid = new OID(oidStr);
List<TreeEvent> events = treeUtils.getSubtree(target, oid);
snmp.close();
if(events == null || events.size() == 0){
throw new Exception("No data.");
}
Map<String, String> result = new HashMap<String, String>();
for (TreeEvent event : events) {
if(event == null) {
continue;
}
if (event.isError()) {
System.err.println(event.getErrorMessage());
continue;
}
VariableBinding[] varBindings = event.getVariableBindings();
for (VariableBinding varBinding : varBindings) {
if (varBinding == null) {
continue;
}
result.put(varBinding.getOid().toString(), varBinding.getVariable().toString());
}
}
return result;
}
}

View File

@ -0,0 +1,63 @@
package com.loafle.crawler.snmp;
/**
* Created by insanity on 17. 4. 7.
*/
import org.snmp4j.CommunityTarget;
import org.snmp4j.PDU;
import org.snmp4j.Snmp;
import org.snmp4j.TransportMapping;
import org.snmp4j.mp.SnmpConstants;
import org.snmp4j.smi.*;
import org.snmp4j.transport.DefaultUdpTransportMapping;
import org.snmp4j.util.DefaultPDUFactory;
import org.snmp4j.util.TreeUtils;
import java.util.Map;
public class SNMPv2c extends SNMP {
private CommunityTarget getTarget(String addr, String port, String community) {
UdpAddress address = new UdpAddress(addr + "/" + port);
CommunityTarget target = new CommunityTarget();
target.setCommunity(new OctetString(community));
target.setAddress(address);
target.setRetries(2);
target.setTimeout(5000);
target.setVersion(SnmpConstants.version2c);
return target;
}
public Map<String, String> walk(String addr, String port, String community, String oidStr) throws Exception {
TransportMapping<? extends Address> transport = new DefaultUdpTransportMapping();
Snmp snmp = new Snmp(transport);
transport.listen();
TreeUtils treeUtils = new TreeUtils(snmp, new DefaultPDUFactory());
CommunityTarget target = getTarget(addr, port, community);
return super.walk(snmp, oidStr, target, treeUtils);
}
public Map<String, String> get(String addr, String port, String community, String[] oids) throws Exception {
TransportMapping<? extends Address> transport = new DefaultUdpTransportMapping();
Snmp snmp = new Snmp(transport);
transport.listen();
CommunityTarget target = getTarget(addr, port, community);
PDU pdu = new PDU();
for (String oid : oids) {
pdu.add(new VariableBinding(new OID(oid)));
}
pdu.setType(PDU.GET);
pdu.setRequestID(new Integer32(1));
return super.get(snmp, pdu, target);
}
}

View File

@ -0,0 +1,139 @@
package com.loafle.crawler.snmp;
import org.snmp4j.*;
import org.snmp4j.mp.MPv3;
import org.snmp4j.mp.MessageProcessingModel;
import org.snmp4j.mp.SnmpConstants;
import org.snmp4j.security.*;
import org.snmp4j.smi.*;
import org.snmp4j.transport.DefaultUdpTransportMapping;
import org.snmp4j.util.PDUFactory;
import org.snmp4j.util.TreeUtils;
import java.util.Map;
/**
* Created by insanity on 17. 4. 10.
*/
public class SNMPv3 extends SNMP {
public Map<String, String> walk(String addr, String port, String user, int authType, String authPass, int privType, String privPass, String oidStr)
throws Exception {
TransportMapping<? extends Address> transport = new DefaultUdpTransportMapping();
Snmp snmp = new Snmp(transport);
transport.listen();
USM usm = new USM(SecurityProtocols.getInstance(), new OctetString(MPv3.createLocalEngineID()), 0);
SecurityModels.getInstance().addSecurityModel(usm);
UsmUser usmUser = getUser(user, authType, authPass, privType, privPass);
snmp.getUSM().addUser(new OctetString(user), usmUser);
TreeUtils treeUtils = new TreeUtils(snmp, new PDUFactory() {
public PDU createPDU(Target target) {
ScopedPDU sp = new ScopedPDU();
sp.setRequestID(new Integer32(1));
return sp;
}
public PDU createPDU(MessageProcessingModel messageProcessingModel) {
return new ScopedPDU();
}
});
Target target = getTarget(addr, port, usmUser);
return super.walk(snmp, oidStr, target, treeUtils);
}
public Map<String, String> get(String addr, String port, String user, int authType, String authPass, int privType, String privPass, String[] oids)
throws Exception {
TransportMapping<? extends Address> transport = new DefaultUdpTransportMapping();
Snmp snmp = new Snmp(transport);
transport.listen();
USM usm = new USM(SecurityProtocols.getInstance(), new OctetString(MPv3.createLocalEngineID()), 0);
SecurityModels.getInstance().addSecurityModel(usm);
UsmUser usmUser = getUser(user, authType, authPass, privType, privPass);
snmp.getUSM().addUser(new OctetString(user), usmUser);
PDU pdu = new ScopedPDU();
for (String oid : oids) {
pdu.addOID(new VariableBinding(new OID(oid)));
}
pdu.setType(PDU.GET);
pdu.setRequestID(new Integer32(1));
Target target = getTarget(addr, port, usmUser);
return super.get(snmp, pdu, target);
}
private UserTarget getTarget(String addr, String port, UsmUser user) {
UdpAddress address = new UdpAddress(addr + "/" + port);
UserTarget target = new UserTarget();
target.setAddress(address);
target.setRetries(2);
target.setTimeout(5000);
target.setVersion(SnmpConstants.version3);
target.setSecurityModel(user.getSecurityModel());
int secLv;
OID autyType = user.getAuthenticationProtocol();
OID privType = user.getPrivacyProtocol();
if (autyType != null && privType != null) {
secLv = SecurityLevel.AUTH_PRIV;
}else if (autyType != null && privType == null) {
secLv = SecurityLevel.AUTH_NOPRIV;
}else {
secLv = SecurityLevel.NOAUTH_NOPRIV;
}
target.setSecurityLevel(secLv);
target.setSecurityName(new OctetString(user.getSecurityName()));
return target;
}
private UsmUser getUser(String user, int authType, String authPass, int privType, String privPass) {
OctetString octetUser = new OctetString(user);
OctetString octetAuthPass = authPass.equals("") ? null : new OctetString(authPass);
OctetString octetPrivPass = privPass.equals("") ? null : new OctetString(privPass);
UsmUser usmUser = new UsmUser(octetUser, getAuthOID(authType), octetAuthPass, getPrivOID(privType), octetPrivPass);
return usmUser;
}
private OID getAuthOID(int authType) {
OID authOID = null;
switch(authType) {
case 0:
authOID = null;
break;
case 1:
authOID = AuthMD5.ID;
break;
case 2:
authOID = AuthSHA.ID;
break;
}
return authOID;
}
private OID getPrivOID(int privType) {
OID privOID = null;
switch(privType) {
case 0:
privOID = null;
break;
case 1:
privOID = PrivDES.ID;
break;
case 2:
privOID = PrivAES128.ID;
break;
}
return privOID;
}
}

0
src/main/resources/_ Normal file
View File

View File

@ -0,0 +1,11 @@
package com.loafle;
import static org.junit.Assert.*;
import org.junit.Test;
public class AppTest {
@Test
public void testSum() {
fail("Not yet implemented");
}
}

View File

@ -0,0 +1,17 @@
<?xml version="1.0" encoding="UTF-8"?>
<configuration scan="true" scanPeriod="3 seconds">
<contextName>snmp_crawler</contextName>
<!-- TRACE > DEBUG > INFO > WARN > ERROR -->
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<pattern>
%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{32} - %msg%n
</pattern>
</encoder>
</appender>
<root level="DEBUG">
<appender-ref ref="STDOUT" />
</root>
<logger name="com.loafle" level="ALL" />
</configuration>