test
This commit is contained in:
parent
2f370b1a30
commit
f9df081a8f
|
@ -1,71 +0,0 @@
|
||||||
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());
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
136
src/main/java/com/loafle/overflow/crawler/Crawler.java
Normal file
136
src/main/java/com/loafle/overflow/crawler/Crawler.java
Normal file
|
@ -0,0 +1,136 @@
|
||||||
|
package com.loafle.overflow.crawler;
|
||||||
|
|
||||||
|
import org.snmp4j.Snmp;
|
||||||
|
import org.snmp4j.TransportMapping;
|
||||||
|
import org.snmp4j.smi.Address;
|
||||||
|
import org.snmp4j.transport.DefaultUdpTransportMapping;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
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() {
|
||||||
|
Snmp snmp = null;
|
||||||
|
TransportMapping<? extends Address> transport = null;
|
||||||
|
try {
|
||||||
|
transport = new DefaultUdpTransportMapping();
|
||||||
|
snmp = new Snmp(transport);
|
||||||
|
transport.listen();
|
||||||
|
SNMPv2c snmpV2 = new SNMPv2c(snmp);
|
||||||
|
|
||||||
|
Boolean isOk = snmpV2.validate(addr, port, community);
|
||||||
|
System.out.println("validate: " + isOk);
|
||||||
|
Map walkResult = snmpV2.walk(addr, port, community, "1.3.6.1.2.1.25.2.3.1.3");
|
||||||
|
printResult(walkResult);
|
||||||
|
Map getResult = snmpV2.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();
|
||||||
|
} finally {
|
||||||
|
if (snmp != null) {
|
||||||
|
try {
|
||||||
|
snmp.close();
|
||||||
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (transport != null) {
|
||||||
|
try {
|
||||||
|
transport.close();
|
||||||
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void useV3() {
|
||||||
|
Snmp snmp = null;
|
||||||
|
TransportMapping<? extends Address> transport = null;
|
||||||
|
|
||||||
|
try {
|
||||||
|
transport = new DefaultUdpTransportMapping();
|
||||||
|
snmp = new Snmp(transport);
|
||||||
|
transport.listen();
|
||||||
|
SNMPv3 snmpV3 = new SNMPv3(snmp);
|
||||||
|
|
||||||
|
Boolean isOk = snmpV3.validate(addr, port, user, authType, authPass, privType, privPass);
|
||||||
|
System.out.println("validate: " + isOk);
|
||||||
|
Map walkResult = snmpV3.walk(addr, port, user, authType, authPass, privType, privPass, "1.3.6.1.2.1.25.2.3.1.3");
|
||||||
|
printResult(walkResult);
|
||||||
|
Map getResult = snmpV3.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();
|
||||||
|
} finally {
|
||||||
|
if (snmp != null) {
|
||||||
|
try {
|
||||||
|
snmp.close();
|
||||||
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (transport != null) {
|
||||||
|
try {
|
||||||
|
transport.close();
|
||||||
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void printResult(Map<String, String> result) {
|
||||||
|
|
||||||
|
for (Map.Entry<String, String> entry : result.entrySet()) {
|
||||||
|
System.out.printf("oid: %s - value: %s\n", entry.getKey(), entry.getValue());
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public String add(String configPath) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
public String init(String configPath) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
public String get(String id) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
public String remove(String id) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,4 +1,4 @@
|
||||||
package com.loafle.crawler.snmp;
|
package com.loafle.overflow.crawler;
|
||||||
|
|
||||||
import org.snmp4j.PDU;
|
import org.snmp4j.PDU;
|
||||||
import org.snmp4j.Snmp;
|
import org.snmp4j.Snmp;
|
||||||
|
@ -21,7 +21,6 @@ public abstract class SNMP {
|
||||||
protected Map<String, String> get(Snmp snmp, PDU pdu, Target target) throws Exception {
|
protected Map<String, String> get(Snmp snmp, PDU pdu, Target target) throws Exception {
|
||||||
|
|
||||||
ResponseEvent response = snmp.get(pdu, target);
|
ResponseEvent response = snmp.get(pdu, target);
|
||||||
snmp.close();
|
|
||||||
|
|
||||||
if (response == null) {
|
if (response == null) {
|
||||||
throw new Exception("Error: No response from SNMP Agent.");
|
throw new Exception("Error: No response from SNMP Agent.");
|
||||||
|
@ -53,7 +52,6 @@ public abstract class SNMP {
|
||||||
protected Map<String, String> walk(Snmp snmp, String oidStr, Target target, TreeUtils treeUtils) throws Exception {
|
protected Map<String, String> walk(Snmp snmp, String oidStr, Target target, TreeUtils treeUtils) throws Exception {
|
||||||
OID oid = new OID(oidStr);
|
OID oid = new OID(oidStr);
|
||||||
List<TreeEvent> events = treeUtils.getSubtree(target, oid);
|
List<TreeEvent> events = treeUtils.getSubtree(target, oid);
|
||||||
snmp.close();
|
|
||||||
|
|
||||||
if(events == null || events.size() == 0){
|
if(events == null || events.size() == 0){
|
||||||
throw new Exception("No data.");
|
throw new Exception("No data.");
|
|
@ -1,4 +1,4 @@
|
||||||
package com.loafle.crawler.snmp;
|
package com.loafle.overflow.crawler;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Created by insanity on 17. 4. 7.
|
* Created by insanity on 17. 4. 7.
|
||||||
|
@ -7,10 +7,8 @@ package com.loafle.crawler.snmp;
|
||||||
import org.snmp4j.CommunityTarget;
|
import org.snmp4j.CommunityTarget;
|
||||||
import org.snmp4j.PDU;
|
import org.snmp4j.PDU;
|
||||||
import org.snmp4j.Snmp;
|
import org.snmp4j.Snmp;
|
||||||
import org.snmp4j.TransportMapping;
|
|
||||||
import org.snmp4j.mp.SnmpConstants;
|
import org.snmp4j.mp.SnmpConstants;
|
||||||
import org.snmp4j.smi.*;
|
import org.snmp4j.smi.*;
|
||||||
import org.snmp4j.transport.DefaultUdpTransportMapping;
|
|
||||||
import org.snmp4j.util.DefaultPDUFactory;
|
import org.snmp4j.util.DefaultPDUFactory;
|
||||||
import org.snmp4j.util.TreeUtils;
|
import org.snmp4j.util.TreeUtils;
|
||||||
|
|
||||||
|
@ -18,6 +16,12 @@ import java.util.Map;
|
||||||
|
|
||||||
public class SNMPv2c extends SNMP {
|
public class SNMPv2c extends SNMP {
|
||||||
|
|
||||||
|
private Snmp snmp = null;
|
||||||
|
|
||||||
|
public SNMPv2c(Snmp snmp) {
|
||||||
|
this.snmp = snmp;
|
||||||
|
}
|
||||||
|
|
||||||
private CommunityTarget getTarget(String addr, String port, String community) {
|
private CommunityTarget getTarget(String addr, String port, String community) {
|
||||||
UdpAddress address = new UdpAddress(addr + "/" + port);
|
UdpAddress address = new UdpAddress(addr + "/" + port);
|
||||||
CommunityTarget target = new CommunityTarget();
|
CommunityTarget target = new CommunityTarget();
|
||||||
|
@ -29,25 +33,24 @@ public class SNMPv2c extends SNMP {
|
||||||
return target;
|
return target;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Boolean validate(String addr, String port, String community) throws Exception {
|
||||||
|
String testOid = "1.3.6.1.2.1.1.3.0";
|
||||||
|
Map<String, String> result = this.get(addr, port, community, new String[]{testOid});
|
||||||
|
if (result.get(testOid) != null) return true;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
public Map<String, String> walk(String addr, String port, String community, String oidStr) throws Exception {
|
public Map<String, String> walk(String addr, String port, String community, String oidStr) throws Exception {
|
||||||
|
|
||||||
TransportMapping<? extends Address> transport = new DefaultUdpTransportMapping();
|
TreeUtils treeUtils = new TreeUtils(this.snmp, new DefaultPDUFactory());
|
||||||
Snmp snmp = new Snmp(transport);
|
|
||||||
transport.listen();
|
|
||||||
|
|
||||||
TreeUtils treeUtils = new TreeUtils(snmp, new DefaultPDUFactory());
|
|
||||||
CommunityTarget target = getTarget(addr, port, community);
|
CommunityTarget target = getTarget(addr, port, community);
|
||||||
|
|
||||||
return super.walk(snmp, oidStr, target, treeUtils);
|
return super.walk(this.snmp, oidStr, target, treeUtils);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public Map<String, String> get(String addr, String port, String community, String[] oids) throws Exception {
|
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);
|
CommunityTarget target = getTarget(addr, port, community);
|
||||||
|
|
||||||
PDU pdu = new PDU();
|
PDU pdu = new PDU();
|
||||||
|
@ -57,7 +60,7 @@ public class SNMPv2c extends SNMP {
|
||||||
pdu.setType(PDU.GET);
|
pdu.setType(PDU.GET);
|
||||||
pdu.setRequestID(new Integer32(1));
|
pdu.setRequestID(new Integer32(1));
|
||||||
|
|
||||||
return super.get(snmp, pdu, target);
|
return super.get(this.snmp, pdu, target);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
|
@ -1,4 +1,4 @@
|
||||||
package com.loafle.crawler.snmp;
|
package com.loafle.overflow.crawler;
|
||||||
|
|
||||||
import org.snmp4j.*;
|
import org.snmp4j.*;
|
||||||
import org.snmp4j.mp.MPv3;
|
import org.snmp4j.mp.MPv3;
|
||||||
|
@ -17,20 +17,29 @@ import java.util.Map;
|
||||||
*/
|
*/
|
||||||
public class SNMPv3 extends SNMP {
|
public class SNMPv3 extends SNMP {
|
||||||
|
|
||||||
|
private Snmp snmp = null;
|
||||||
|
|
||||||
|
public SNMPv3(Snmp snmp) {
|
||||||
|
this.snmp = snmp;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Boolean validate(String addr, String port, String user, int authType, String authPass, int 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, int authType, String authPass, int privType, String privPass, String oidStr)
|
||||||
throws Exception {
|
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);
|
USM usm = new USM(SecurityProtocols.getInstance(), new OctetString(MPv3.createLocalEngineID()), 0);
|
||||||
SecurityModels.getInstance().addSecurityModel(usm);
|
SecurityModels.getInstance().addSecurityModel(usm);
|
||||||
|
|
||||||
UsmUser usmUser = getUser(user, authType, authPass, privType, privPass);
|
UsmUser usmUser = getUser(user, authType, authPass, privType, privPass);
|
||||||
snmp.getUSM().addUser(new OctetString(user), usmUser);
|
this.snmp.getUSM().addUser(new OctetString(user), usmUser);
|
||||||
|
|
||||||
|
|
||||||
TreeUtils treeUtils = new TreeUtils(snmp, new PDUFactory() {
|
TreeUtils treeUtils = new TreeUtils(this.snmp, new PDUFactory() {
|
||||||
public PDU createPDU(Target target) {
|
public PDU createPDU(Target target) {
|
||||||
ScopedPDU sp = new ScopedPDU();
|
ScopedPDU sp = new ScopedPDU();
|
||||||
sp.setRequestID(new Integer32(1));
|
sp.setRequestID(new Integer32(1));
|
||||||
|
@ -43,7 +52,7 @@ public class SNMPv3 extends SNMP {
|
||||||
});
|
});
|
||||||
|
|
||||||
Target target = getTarget(addr, port, usmUser);
|
Target target = getTarget(addr, port, usmUser);
|
||||||
return super.walk(snmp, oidStr, target, treeUtils);
|
return super.walk(this.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)
|
public Map<String, String> get(String addr, String port, String user, int authType, String authPass, int privType, String privPass, String[] oids)
|
||||||
|
@ -57,7 +66,7 @@ public class SNMPv3 extends SNMP {
|
||||||
SecurityModels.getInstance().addSecurityModel(usm);
|
SecurityModels.getInstance().addSecurityModel(usm);
|
||||||
|
|
||||||
UsmUser usmUser = getUser(user, authType, authPass, privType, privPass);
|
UsmUser usmUser = getUser(user, authType, authPass, privType, privPass);
|
||||||
snmp.getUSM().addUser(new OctetString(user), usmUser);
|
this.snmp.getUSM().addUser(new OctetString(user), usmUser);
|
||||||
|
|
||||||
PDU pdu = new ScopedPDU();
|
PDU pdu = new ScopedPDU();
|
||||||
for (String oid : oids) {
|
for (String oid : oids) {
|
Loading…
Reference in New Issue
Block a user