test
This commit is contained in:
parent
3201bf605c
commit
05832e8df6
4
pom.xml
4
pom.xml
|
@ -11,10 +11,8 @@
|
|||
</parent>
|
||||
|
||||
<groupId>com.loafle.overflow</groupId>
|
||||
<artifactId>crawler.snmp</artifactId>
|
||||
<packaging>jar</packaging>
|
||||
<artifactId>crawler_snmp</artifactId>
|
||||
<version>1.0.0-SNAPSHOT</version>
|
||||
<name>com.loafle.overflow.crawler.snmp</name>
|
||||
|
||||
<dependencies>
|
||||
<!-- https://mvnrepository.com/artifact/org.snmp4j/snmp4j -->
|
||||
|
|
|
@ -17,8 +17,8 @@
|
|||
<orderEntry type="library" name="Maven: com.loafle.overflow:crawler_java:1.0.0-SNAPSHOT" 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" />
|
||||
<orderEntry type="library" name="Maven: org.slf4j:slf4j-api:1.7.25" level="project" />
|
||||
<orderEntry type="library" scope="RUNTIME" name="Maven: ch.qos.logback:logback-classic:1.2.3" level="project" />
|
||||
<orderEntry type="library" scope="RUNTIME" name="Maven: ch.qos.logback:logback-core:1.2.3" level="project" />
|
||||
</component>
|
||||
</module>
|
|
@ -16,41 +16,27 @@ import java.util.Map;
|
|||
*/
|
||||
public class SNMPCrawler extends 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 enum MethodType {
|
||||
VALIDATE, GET, WALK;
|
||||
}
|
||||
|
||||
@Override
|
||||
protected Object getInternal(Map<String, Object> config) {
|
||||
//return getByV2c(MethodType.VALIDATE, null);
|
||||
//return getByV2c(MethodType.GET, new String[]{"1.3.6.1.2.1.1.5.0", "1.3.6.1.2.1.2.2.1.6.2"});
|
||||
return getByV2c(MethodType.WALK, new String[]{"1.3.6.1.2.1.25.2.3.1.3"});
|
||||
public Object getInternal(Map<String, Object> config) {
|
||||
|
||||
String targetVer = (String)config.get("version");
|
||||
Object retObj = null;
|
||||
|
||||
//return getByV3(MethodType.VALIDATE, null);
|
||||
//return getByV3(MethodType.GET, new String[]{"1.3.6.1.2.1.1.5.0", "1.3.6.1.2.1.2.2.1.6.2"});
|
||||
//return getByV3(MethodType.WALK, new String[]{"1.3.6.1.2.1.25.2.3.1.3"});
|
||||
switch (targetVer) {
|
||||
case "v2c":
|
||||
retObj = getByV2c(config);
|
||||
break;
|
||||
case "v3":
|
||||
retObj = getByV3(config);
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
||||
return retObj;
|
||||
}
|
||||
|
||||
private Object getByV2c(MethodType type, String[] oids) {
|
||||
private Object getByV2c(Map<String, Object> config) {
|
||||
Snmp snmp = null;
|
||||
TransportMapping<? extends Address> transport = null;
|
||||
try {
|
||||
|
@ -59,13 +45,18 @@ public class SNMPCrawler extends Crawler {
|
|||
transport.listen();
|
||||
SNMPv2c snmpV2 = new SNMPv2c(snmp);
|
||||
|
||||
switch (type) {
|
||||
case VALIDATE:
|
||||
return snmpV2.validate(addr, port, community);
|
||||
case GET:
|
||||
return snmpV2.get(addr, port, community, oids);
|
||||
case WALK:
|
||||
return snmpV2.walk(addr, port, community, oids[0]);
|
||||
String ip = (String)config.get("ip");
|
||||
String port = (String)config.get("port");
|
||||
String community = (String)config.get("community");
|
||||
String[] oids = (String[])config.get("oids");
|
||||
|
||||
switch ((String)config.get("method")) {
|
||||
case "validate":
|
||||
return snmpV2.validate(ip, port, community);
|
||||
case "get":
|
||||
return snmpV2.get(ip, port, community, oids);
|
||||
case "walk":
|
||||
return snmpV2.walk(ip, port, community, oids[0]);
|
||||
default:
|
||||
return null;
|
||||
}
|
||||
|
@ -93,7 +84,7 @@ public class SNMPCrawler extends Crawler {
|
|||
return null;
|
||||
}
|
||||
|
||||
private Object getByV3(MethodType type, String[] oids) {
|
||||
private Object getByV3(Map<String, Object> config) {
|
||||
Snmp snmp = null;
|
||||
TransportMapping<? extends Address> transport = null;
|
||||
|
||||
|
@ -103,13 +94,22 @@ public class SNMPCrawler extends Crawler {
|
|||
transport.listen();
|
||||
SNMPv3 snmpV3 = new SNMPv3(snmp);
|
||||
|
||||
switch (type) {
|
||||
case VALIDATE:
|
||||
return snmpV3.validate(addr, port, user, authType, authPass, privType, privPass);
|
||||
case GET:
|
||||
return snmpV3.get(addr, port, user, authType, authPass, privType, privPass, oids);
|
||||
case WALK:
|
||||
return snmpV3.walk(addr, port, user, authType, authPass, privType, privPass, oids[0]);
|
||||
String ip = (String)config.get("ip");
|
||||
String port = (String)config.get("port");
|
||||
String user = (String)config.get("user");
|
||||
String authType = (String)config.get("authType");
|
||||
String authPass = (String)config.get("authPass");
|
||||
String privType = (String)config.get("privType");
|
||||
String privPass = (String)config.get("privPass");
|
||||
String[] oids = (String[])config.get("oids");
|
||||
|
||||
switch ((String)config.get("method")) {
|
||||
case "validate":
|
||||
return snmpV3.validate(ip, port, user, authType, authPass, privType, privPass);
|
||||
case "get":
|
||||
return snmpV3.get(ip, port, user, authType, authPass, privType, privPass, oids);
|
||||
case "walk":
|
||||
return snmpV3.walk(ip, port, user, authType, authPass, privType, privPass, oids[0]);
|
||||
default:
|
||||
return null;
|
||||
}
|
||||
|
|
|
@ -9,7 +9,7 @@ import org.snmp4j.smi.VariableBinding;
|
|||
import org.snmp4j.util.TreeEvent;
|
||||
import org.snmp4j.util.TreeUtils;
|
||||
|
||||
import java.util.HashMap;
|
||||
import java.util.LinkedHashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
|
@ -39,7 +39,7 @@ public abstract class SNMP {
|
|||
throw new Exception("Error: " + errorIndex + " " + errorStatusText);
|
||||
}
|
||||
|
||||
Map<String, String> result = new HashMap<String, String>();
|
||||
Map<String, String> result = new LinkedHashMap<String, String>();
|
||||
for (VariableBinding varBinding : responsePDU.getVariableBindings()) {
|
||||
if (varBinding == null) {
|
||||
continue;
|
||||
|
@ -49,7 +49,7 @@ public abstract class SNMP {
|
|||
return result;
|
||||
}
|
||||
|
||||
protected Map<String, String> walk(Snmp snmp, String oidStr, Target target, TreeUtils treeUtils) throws Exception {
|
||||
protected Map<String, String> walk(String oidStr, Target target, TreeUtils treeUtils) throws Exception {
|
||||
OID oid = new OID(oidStr);
|
||||
List<TreeEvent> events = treeUtils.getSubtree(target, oid);
|
||||
|
||||
|
@ -57,7 +57,7 @@ public abstract class SNMP {
|
|||
throw new Exception("No data.");
|
||||
}
|
||||
|
||||
Map<String, String> result = new HashMap<String, String>();
|
||||
Map<String, String> result = new LinkedHashMap<String, String>();
|
||||
for (TreeEvent event : events) {
|
||||
if(event == null) {
|
||||
continue;
|
||||
|
|
|
@ -45,7 +45,7 @@ public class SNMPv2c extends SNMP {
|
|||
TreeUtils treeUtils = new TreeUtils(this.snmp, new DefaultPDUFactory());
|
||||
CommunityTarget target = getTarget(addr, port, community);
|
||||
|
||||
return super.walk(this.snmp, oidStr, target, treeUtils);
|
||||
return super.walk(oidStr, target, treeUtils);
|
||||
}
|
||||
|
||||
|
||||
|
|
|
@ -23,14 +23,14 @@ public class SNMPv3 extends SNMP {
|
|||
this.snmp = snmp;
|
||||
}
|
||||
|
||||
public Boolean validate(String addr, String port, String user, int authType, String authPass, int privType, String privPass) throws Exception {
|
||||
public Boolean validate(String addr, String port, String user, String authType, String authPass, String privType, String privPass) throws Exception {
|
||||
String testOid = "1.3.6.1.2.1.1.3.0";
|
||||
Map<String, String> result = this.get(addr, port, user, authType, authPass, privType, privPass, new String[]{testOid});
|
||||
if (result.get(testOid) != null) return true;
|
||||
return false;
|
||||
}
|
||||
|
||||
public Map<String, String> walk(String addr, String port, String user, int authType, String authPass, int privType, String privPass, String oidStr)
|
||||
public Map<String, String> walk(String addr, String port, String user, String authType, String authPass, String privType, String privPass, String oidStr)
|
||||
throws Exception {
|
||||
USM usm = new USM(SecurityProtocols.getInstance(), new OctetString(MPv3.createLocalEngineID()), 0);
|
||||
SecurityModels.getInstance().addSecurityModel(usm);
|
||||
|
@ -52,10 +52,10 @@ public class SNMPv3 extends SNMP {
|
|||
});
|
||||
|
||||
Target target = getTarget(addr, port, usmUser);
|
||||
return super.walk(this.snmp, oidStr, target, treeUtils);
|
||||
return super.walk(oidStr, target, treeUtils);
|
||||
}
|
||||
|
||||
public Map<String, String> get(String addr, String port, String user, int authType, String authPass, int privType, String privPass, String[] oids)
|
||||
public Map<String, String> get(String addr, String port, String user, String authType, String authPass, String privType, String privPass, String[] oids)
|
||||
throws Exception {
|
||||
|
||||
TransportMapping<? extends Address> transport = new DefaultUdpTransportMapping();
|
||||
|
@ -105,7 +105,7 @@ public class SNMPv3 extends SNMP {
|
|||
return target;
|
||||
}
|
||||
|
||||
private UsmUser getUser(String user, int authType, String authPass, int privType, String privPass) {
|
||||
private UsmUser getUser(String user, String authType, String authPass, String privType, String privPass) {
|
||||
OctetString octetUser = new OctetString(user);
|
||||
OctetString octetAuthPass = authPass.equals("") ? null : new OctetString(authPass);
|
||||
OctetString octetPrivPass = privPass.equals("") ? null : new OctetString(privPass);
|
||||
|
@ -114,32 +114,32 @@ public class SNMPv3 extends SNMP {
|
|||
return usmUser;
|
||||
}
|
||||
|
||||
private OID getAuthOID(int authType) {
|
||||
private OID getAuthOID(String authType) {
|
||||
OID authOID = null;
|
||||
switch(authType) {
|
||||
case 0:
|
||||
case "":
|
||||
authOID = null;
|
||||
break;
|
||||
case 1:
|
||||
case "MD5":
|
||||
authOID = AuthMD5.ID;
|
||||
break;
|
||||
case 2:
|
||||
case "SHA":
|
||||
authOID = AuthSHA.ID;
|
||||
break;
|
||||
}
|
||||
return authOID;
|
||||
}
|
||||
|
||||
private OID getPrivOID(int privType) {
|
||||
private OID getPrivOID(String privType) {
|
||||
OID privOID = null;
|
||||
switch(privType) {
|
||||
case 0:
|
||||
case "":
|
||||
privOID = null;
|
||||
break;
|
||||
case 1:
|
||||
case "DES":
|
||||
privOID = PrivDES.ID;
|
||||
break;
|
||||
case 2:
|
||||
case "AES":
|
||||
privOID = PrivAES128.ID;
|
||||
break;
|
||||
}
|
||||
|
|
|
@ -5,13 +5,48 @@ import static org.junit.Assert.*;
|
|||
import com.loafle.overflow.crawler.snmp.SNMPCrawler;
|
||||
import org.junit.Test;
|
||||
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
import java.util.SortedSet;
|
||||
import java.util.TreeSet;
|
||||
|
||||
public class AppTest {
|
||||
|
||||
/***
|
||||
* v2c test info
|
||||
* private static String addr = "192.168.1.215";
|
||||
* private static String port = "161";
|
||||
* private static String community = "public";
|
||||
*
|
||||
* v3 test info
|
||||
* loafle MD5 "qwer5795" DES "qweqwe123" : AUTHPRIV
|
||||
* loafle2 SHA "qwer5795" AES "qweqwe123" : AUTHPRIV
|
||||
* loafle3 MD5 "qwer5795" : AUTHNOPRIV
|
||||
* loafle4 :NOAUTHNOPRIV
|
||||
*/
|
||||
@Test
|
||||
public void testSNMP2() {
|
||||
public void testSNMP() {
|
||||
SNMPCrawler c = new SNMPCrawler();
|
||||
Object res = c.get("1111");
|
||||
Map config = new HashMap();
|
||||
|
||||
config.put("ip", "192.168.1.215");
|
||||
config.put("port", "161");
|
||||
|
||||
// config.put("version", "v2c");
|
||||
// config.put("community", "public");
|
||||
// config.put("method", "get");
|
||||
// config.put("oids", new String[]{"1.3.6.1.2.1.1.5.0", "1.3.6.1.2.1.2.2.1.6.2"});
|
||||
|
||||
config.put("version", "v3");
|
||||
config.put("user", "loafle");
|
||||
config.put("authType", "MD5");
|
||||
config.put("authPass", "qwer5795");
|
||||
config.put("privType", "DES");
|
||||
config.put("privPass", "qweqwe123");
|
||||
config.put("method", "walk");
|
||||
config.put("oids", new String[]{"1.3.6.1.2.1.25.2.3.1.3"});
|
||||
|
||||
Object res = c.getInternal(config);
|
||||
|
||||
if(res instanceof Boolean) {
|
||||
System.out.println("validate : " + res);
|
||||
|
|
Loading…
Reference in New Issue
Block a user