292 lines
15 KiB
Java
292 lines
15 KiB
Java
package com.zdjizhi.etl;
|
||
|
||
import cn.hutool.log.Log;
|
||
import cn.hutool.log.LogFactory;
|
||
import com.fasterxml.jackson.databind.JavaType;
|
||
import com.zdjizhi.common.CommonConfig;
|
||
import com.zdjizhi.common.DosDetectionThreshold;
|
||
import com.zdjizhi.common.DosVsysId;
|
||
import com.zdjizhi.utils.HttpClientUtils;
|
||
import com.zdjizhi.utils.JsonMapper;
|
||
import com.zdjizhi.utils.NacosUtils;
|
||
import inet.ipaddr.IPAddress;
|
||
import inet.ipaddr.IPAddressString;
|
||
import org.apache.flink.shaded.guava18.com.google.common.collect.Range;
|
||
import org.apache.flink.shaded.guava18.com.google.common.collect.TreeRangeMap;
|
||
import org.apache.http.client.utils.URIBuilder;
|
||
import org.apache.http.message.BasicHeader;
|
||
|
||
import java.net.URISyntaxException;
|
||
import java.util.ArrayList;
|
||
import java.util.HashMap;
|
||
import java.util.Map;
|
||
|
||
/**
|
||
* @author wlh
|
||
*/
|
||
public class ParseStaticThreshold {
|
||
// private static Logger logger = LoggerFactory.getLogger(ParseStaticThreshold.class);
|
||
private static final Log logger = LogFactory.get();
|
||
private static String encryptpwd;
|
||
|
||
private static JsonMapper jsonMapperInstance = JsonMapper.getInstance();
|
||
private static JavaType hashmapJsonType = jsonMapperInstance.createCollectionType(HashMap.class, String.class, Object.class);
|
||
private static JavaType thresholdType = jsonMapperInstance.createCollectionType(ArrayList.class, DosDetectionThreshold.class);
|
||
private static JavaType vsysIDType = jsonMapperInstance.createCollectionType(ArrayList.class, DosVsysId.class);
|
||
|
||
static {
|
||
//加载加密登录密码
|
||
encryptpwd = getEncryptpwd();
|
||
}
|
||
|
||
/**
|
||
* 获取加密密码
|
||
*/
|
||
private static String getEncryptpwd() {
|
||
String psw = HttpClientUtils.ERROR_MESSAGE;
|
||
try {
|
||
URIBuilder uriBuilder = new URIBuilder(CommonConfig.BIFANG_SERVER_URI);
|
||
HashMap<String, Object> parms = new HashMap<>();
|
||
parms.put("password", "admin");
|
||
HttpClientUtils.setUrlWithParams(uriBuilder, CommonConfig.BIFANG_SERVER_ENCRYPTPWD_PATH, parms);
|
||
String resposeJsonStr = HttpClientUtils.httpGet(uriBuilder.build());
|
||
if (!HttpClientUtils.ERROR_MESSAGE.equals(resposeJsonStr)) {
|
||
HashMap<String, Object> resposeMap = jsonMapperInstance.fromJson(resposeJsonStr, hashmapJsonType);
|
||
boolean success = (boolean) resposeMap.get("success");
|
||
String msg = resposeMap.get("msg").toString();
|
||
if (success) {
|
||
HashMap<String, Object> data = jsonMapperInstance.fromJson(jsonMapperInstance.toJson(resposeMap.get("data")), hashmapJsonType);
|
||
psw = data.get("encryptpwd").toString();
|
||
} else {
|
||
logger.error(msg);
|
||
}
|
||
}
|
||
} catch (URISyntaxException e) {
|
||
logger.error("构造URI异常", e);
|
||
} catch (Exception e) {
|
||
logger.error("获取encryptpwd失败", e);
|
||
}
|
||
return psw;
|
||
}
|
||
|
||
/**
|
||
* 登录bifang服务,获取token
|
||
*
|
||
* @return token
|
||
*/
|
||
private static String loginBifangServer() {
|
||
String token = HttpClientUtils.ERROR_MESSAGE;
|
||
try {
|
||
if (!HttpClientUtils.ERROR_MESSAGE.equals(encryptpwd)) {
|
||
URIBuilder uriBuilder = new URIBuilder(CommonConfig.BIFANG_SERVER_URI);
|
||
HashMap<String, Object> parms = new HashMap<>();
|
||
parms.put("username", "admin");
|
||
parms.put("password", encryptpwd);
|
||
HttpClientUtils.setUrlWithParams(uriBuilder, CommonConfig.BIFANG_SERVER_LOGIN_PATH, parms);
|
||
String resposeJsonStr = HttpClientUtils.httpPost(uriBuilder.build(), null);
|
||
if (!HttpClientUtils.ERROR_MESSAGE.equals(resposeJsonStr)) {
|
||
HashMap<String, Object> resposeMap = jsonMapperInstance.fromJson(resposeJsonStr, hashmapJsonType);
|
||
boolean success = (boolean) resposeMap.get("success");
|
||
String msg = resposeMap.get("msg").toString();
|
||
if (success) {
|
||
HashMap<String, Object> data = jsonMapperInstance.fromJson(jsonMapperInstance.toJson(resposeMap.get("data")), hashmapJsonType);
|
||
token = data.get("token").toString();
|
||
} else {
|
||
logger.error(msg);
|
||
}
|
||
}
|
||
}
|
||
} catch (Exception e) {
|
||
logger.error("登录失败,未获取到token ", e);
|
||
}
|
||
return token;
|
||
}
|
||
|
||
/**
|
||
* 获取vsysId配置列表
|
||
*
|
||
* @return vsysIdList
|
||
*/
|
||
private static ArrayList<DosVsysId> getVsysId() {
|
||
ArrayList<DosVsysId> vsysIdList = null;
|
||
try {
|
||
URIBuilder uriBuilder = new URIBuilder(CommonConfig.BIFANG_SERVER_URI);
|
||
HashMap<String, Object> parms = new HashMap<>();
|
||
parms.put("pageSize", -1);
|
||
// parms.put("orderBy", "vsysId desc");
|
||
parms.put("type", 1);
|
||
HttpClientUtils.setUrlWithParams(uriBuilder, CommonConfig.BIFANG_SERVER_POLICY_VSYSID_PATH, parms);
|
||
String token = NacosUtils.getStringProperty("bifang.server.token");
|
||
if (!HttpClientUtils.ERROR_MESSAGE.equals(token)) {
|
||
BasicHeader authorization = new BasicHeader("Authorization", token);
|
||
BasicHeader authorization1 = new BasicHeader("Content-Type", "application/x-www-form-urlencoded");
|
||
String resposeJsonStr = HttpClientUtils.httpGet(uriBuilder.build(), authorization, authorization1);
|
||
if (!HttpClientUtils.ERROR_MESSAGE.equals(resposeJsonStr)) {
|
||
HashMap<String, Object> resposeMap = jsonMapperInstance.fromJson(resposeJsonStr, hashmapJsonType);
|
||
boolean success = (boolean) resposeMap.get("success");
|
||
String msg = resposeMap.get("msg").toString();
|
||
if (success) {
|
||
HashMap<String, Object> data = jsonMapperInstance.fromJson(jsonMapperInstance.toJson(resposeMap.get("data")), hashmapJsonType);
|
||
Object list = data.get("list");
|
||
if (list != null) {
|
||
vsysIdList = jsonMapperInstance.fromJson(jsonMapperInstance.toJson(list), vsysIDType);
|
||
logger.info("获取到vsysId {}条", vsysIdList.size());
|
||
} else {
|
||
logger.warn("vsysIdList为空");
|
||
}
|
||
} else {
|
||
logger.error(msg);
|
||
}
|
||
}
|
||
}
|
||
} catch (Exception e) {
|
||
logger.error("获取vsysId失败,请检查bifang服务或登录配置信息 ", e);
|
||
}
|
||
return vsysIdList;
|
||
}
|
||
|
||
/**
|
||
* 根据vsysId获取静态阈值配置列表
|
||
*
|
||
* @return thresholds
|
||
*/
|
||
private static ArrayList<DosDetectionThreshold> getDosDetectionThreshold() {
|
||
ArrayList<DosDetectionThreshold> vsysThresholds = new ArrayList<>();
|
||
ArrayList<DosVsysId> vsysIds = getVsysId();
|
||
try {
|
||
if (vsysIds != null) {
|
||
for (DosVsysId dosVsysId : vsysIds) {
|
||
Integer vsysId = dosVsysId.getId() == null ? 1 : dosVsysId.getId();
|
||
Integer[] superiorIds = dosVsysId.getSuperiorIds();
|
||
URIBuilder uriBuilder = new URIBuilder(CommonConfig.BIFANG_SERVER_URI);
|
||
HashMap<String, Object> parms = new HashMap<>();
|
||
parms.put("pageSize", -1);
|
||
parms.put("orderBy", "profileId asc");
|
||
parms.put("isValid", 1);
|
||
parms.put("vsysId", vsysId);
|
||
HttpClientUtils.setUrlWithParams(uriBuilder, CommonConfig.BIFANG_SERVER_POLICY_THRESHOLD_PATH, parms);
|
||
String token = NacosUtils.getStringProperty("bifang.server.token");
|
||
if (!HttpClientUtils.ERROR_MESSAGE.equals(token)) {
|
||
BasicHeader authorization = new BasicHeader("Authorization", token);
|
||
BasicHeader authorization1 = new BasicHeader("Content-Type", "application/x-www-form-urlencoded");
|
||
String resposeJsonStr = HttpClientUtils.httpGet(uriBuilder.build(), authorization, authorization1);
|
||
if (!HttpClientUtils.ERROR_MESSAGE.equals(resposeJsonStr)) {
|
||
HashMap<String, Object> resposeMap = jsonMapperInstance.fromJson(resposeJsonStr, hashmapJsonType);
|
||
boolean success = (boolean) resposeMap.get("success");
|
||
String msg = resposeMap.get("msg").toString();
|
||
if (success) {
|
||
HashMap<String, Object> data = jsonMapperInstance.fromJson(jsonMapperInstance.toJson(resposeMap.get("data")), hashmapJsonType);
|
||
Object list = data.get("list");
|
||
if (list != null) {
|
||
ArrayList<DosDetectionThreshold> thresholds = jsonMapperInstance.fromJson(jsonMapperInstance.toJson(list), thresholdType);
|
||
for (DosDetectionThreshold dosDetectionThreshold : thresholds) {
|
||
dosDetectionThreshold.setSuperiorIds(superiorIds);
|
||
vsysThresholds.add(dosDetectionThreshold);
|
||
}
|
||
logger.info("获取到vsys id是{}静态阈值配置{}条", vsysId, thresholds.size());
|
||
} else {
|
||
logger.warn("静态阈值配置为空");
|
||
}
|
||
} else {
|
||
logger.error(msg);
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
} catch (Exception e) {
|
||
logger.error("获取静态阈值配置失败,请检查bifang服务或登录配置信息 ", e);
|
||
}
|
||
|
||
return vsysThresholds;
|
||
}
|
||
|
||
/**
|
||
* 基于静态阈值构建threshold RangeMap,k:IP段或具体IP,v:配置信息
|
||
*
|
||
* @return threshold RangeMap
|
||
*/
|
||
static HashMap<Integer, HashMap<String, TreeRangeMap<IPAddress, DosDetectionThreshold>>> createStaticThreshold() {
|
||
HashMap<Integer, HashMap<String, TreeRangeMap<IPAddress, DosDetectionThreshold>>> thresholdRangeMap = new HashMap<>(4);
|
||
try {
|
||
ArrayList<DosDetectionThreshold> dosDetectionThreshold = getDosDetectionThreshold();
|
||
if (dosDetectionThreshold != null && !dosDetectionThreshold.isEmpty()) {
|
||
for (DosDetectionThreshold threshold : dosDetectionThreshold) {
|
||
String attackType = threshold.getAttackType();
|
||
int vsysId = threshold.getVsysId();
|
||
HashMap<String, TreeRangeMap<IPAddress, DosDetectionThreshold>> rangeMap = thresholdRangeMap.getOrDefault(vsysId, new HashMap<>());
|
||
|
||
TreeRangeMap<IPAddress, DosDetectionThreshold> treeRangeMap = rangeMap.getOrDefault(attackType, TreeRangeMap.create());
|
||
ArrayList<String> serverIpList = threshold.getServerIpList();
|
||
for (String sip : serverIpList) {
|
||
IPAddressString ipAddressString = new IPAddressString(sip);
|
||
if (ipAddressString.isIPAddress()) {
|
||
IPAddress address = ipAddressString.getAddress();
|
||
if (address.isPrefixed()) {
|
||
IPAddress lower = address.getLower();
|
||
IPAddress upper = address.getUpper();
|
||
if (!address.isMultiple()) {
|
||
lower = address.adjustPrefixLength(address.getBitCount());
|
||
upper = address.toMaxHost().withoutPrefixLength();
|
||
}
|
||
Map.Entry<Range<IPAddress>, DosDetectionThreshold> lowerEntry = treeRangeMap.getEntry(lower);
|
||
Map.Entry<Range<IPAddress>, DosDetectionThreshold> upperEntry = treeRangeMap.getEntry(upper);
|
||
if (lowerEntry != null && upperEntry == null) {
|
||
Range<IPAddress> lowerEntryKey = lowerEntry.getKey();
|
||
DosDetectionThreshold lowerEntryValue = lowerEntry.getValue();
|
||
treeRangeMap.put(Range.closedOpen(lowerEntryKey.lowerEndpoint(), lower), lowerEntryValue);
|
||
treeRangeMap.put(Range.closed(lower, upper), threshold);
|
||
} else if (lowerEntry == null && upperEntry != null) {
|
||
Range<IPAddress> upperEntryKey = upperEntry.getKey();
|
||
DosDetectionThreshold upperEntryValue = upperEntry.getValue();
|
||
treeRangeMap.put(Range.openClosed(upper, upperEntryKey.upperEndpoint()), upperEntryValue);
|
||
treeRangeMap.put(Range.closed(lower, upper), threshold);
|
||
} else {
|
||
treeRangeMap.put(Range.closed(lower, upper), threshold);
|
||
}
|
||
} else {
|
||
treeRangeMap.put(Range.closed(address, address), threshold);
|
||
}
|
||
}
|
||
}
|
||
rangeMap.put(attackType, treeRangeMap);
|
||
thresholdRangeMap.put(vsysId, rangeMap);
|
||
}
|
||
}
|
||
} catch (Exception e) {
|
||
logger.error("构建threshold RangeMap失败", e);
|
||
}
|
||
return thresholdRangeMap;
|
||
}
|
||
|
||
public static void main(String[] args) {
|
||
/*
|
||
ArrayList<DosDetectionThreshold> dosDetectionThreshold = getDosDetectionThreshold();
|
||
// dosDetectionThreshold.forEach(System.out::println);
|
||
getVsysId().forEach(System.out::println);
|
||
System.out.println("------------------------");
|
||
*/
|
||
HashMap<Integer, HashMap<String, TreeRangeMap<IPAddress, DosDetectionThreshold>>> staticThreshold = createStaticThreshold();
|
||
|
||
System.out.println("------------------------");
|
||
|
||
for (Integer integer : staticThreshold.keySet()) {
|
||
HashMap<String, TreeRangeMap<IPAddress, DosDetectionThreshold>> stringTreeRangeMapHashMap = staticThreshold.get(integer);
|
||
for (String type : stringTreeRangeMapHashMap.keySet()) {
|
||
Map<Range<IPAddress>, DosDetectionThreshold> asMapOfRanges = stringTreeRangeMapHashMap.get(type).asMapOfRanges();
|
||
for (Range<IPAddress> range : asMapOfRanges.keySet()) {
|
||
DosDetectionThreshold threshold = asMapOfRanges.get(range);
|
||
System.out.println(integer + "---" + type + "---" + range + "---" + threshold);
|
||
}
|
||
System.out.println("------------------------");
|
||
}
|
||
|
||
}
|
||
// String s = loginBifangServer();
|
||
// System.out.println(s);
|
||
|
||
}
|
||
|
||
|
||
}
|