summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorzhangdongxu <[email protected]>2018-12-27 17:18:47 +0800
committerzhangdongxu <[email protected]>2018-12-27 17:18:47 +0800
commit75e414b7e6b7a10c8d206c6cdd395d954cd6be06 (patch)
treec86f44e1d434ab7980f5f6d4632f4b15c6981f26
parentee7745d281cf300895699537442c9a0d86402283 (diff)
1、修正流量统计二级页面趋势图统计是中,最后一个点补0的问题;
2、流量统计中域名和封堵、监测详情二级界面,查询时间段内无数据的直接返回,不按时间补0;
-rw-r--r--src/main/java/com/nis/web/service/restful/DashboardService.java195
1 files changed, 100 insertions, 95 deletions
diff --git a/src/main/java/com/nis/web/service/restful/DashboardService.java b/src/main/java/com/nis/web/service/restful/DashboardService.java
index 7eb36af..814be38 100644
--- a/src/main/java/com/nis/web/service/restful/DashboardService.java
+++ b/src/main/java/com/nis/web/service/restful/DashboardService.java
@@ -395,67 +395,69 @@ public class DashboardService extends BaseService {
entrance1 = ntcTotalReportDao.getActionTrans(begin, end, 1, sql);
entrance2 = ntcTotalReportDao.getActionTrans(begin, end, 2, sql);
- Map<String, Comparable> m = new HashMap<String, Comparable>();
- Date beginDate = DateUtils.parseDate(begin);
- Date endDate = DateUtils.parseDate(end);
-
- List<Date> dateRangeList = new ArrayList<Date>();
- List<String> strDateRangeList = new ArrayList<String>();
- Calendar calendar = Calendar.getInstance();
- calendar.setTime(beginDate);
- SimpleDateFormat sdf = new SimpleDateFormat("MM-dd HH:mm");
- while (calendar.getTime().compareTo(endDate) <= 0) {
- dateRangeList.add(calendar.getTime());
- strDateRangeList.add(sdf.format(calendar.getTime()));
- calendar.add(Calendar.MINUTE, 5);
- }
- // 存放每个时间点的总数
- Map<String, List<Long>> ipCountListMap = new HashMap<String, List<Long>>();
- int index = 0;
- List sumList1 = new ArrayList();
- List sumList2 = new ArrayList();
- for (int i = 0; i < dateRangeList.size(); i++) {
- // 存放一个时间点中总数
- Map<String, Long> ipCountMap = new HashMap<String, Long>();
- Date date = dateRangeList.get(i);
- Long num1 = 0L;
- Long num2 = 0L;
- for (int j = index; j < entrance1.size(); j++) {
- NtcEntranceReport ipInfo = entrance1.get(j);
- if (ipInfo.getReportTime() != null) {
- if (ipInfo.getReportTime().compareTo(date) >= 0 && (i + 1 < dateRangeList.size()
- && ipInfo.getReportTime().compareTo(dateRangeList.get(i + 1)) < 0)) {
- num1 = num1 + ipInfo.getSum();
- } else {
- index = j;
- break;
+ if(!StringUtil.isEmpty(entrance1)||!StringUtil.isEmpty(entrance2)){
+ Map<String, Comparable> m = new HashMap<String, Comparable>();
+ Date beginDate = DateUtils.parseDate(begin);
+ Date endDate = DateUtils.parseDate(end);
+
+ List<Date> dateRangeList = new ArrayList<Date>();
+ List<String> strDateRangeList = new ArrayList<String>();
+ Calendar calendar = Calendar.getInstance();
+ calendar.setTime(beginDate);
+ SimpleDateFormat sdf = new SimpleDateFormat("MM-dd HH:mm");
+ while (calendar.getTime().compareTo(endDate) < 0) {
+ dateRangeList.add(calendar.getTime());
+ strDateRangeList.add(sdf.format(calendar.getTime()));
+ calendar.add(Calendar.MINUTE, 5);
+ }
+ // 存放每个时间点的总数
+ Map<String, List<Long>> ipCountListMap = new HashMap<String, List<Long>>();
+ int index = 0;
+ List sumList1 = new ArrayList();
+ List sumList2 = new ArrayList();
+ for (int i = 0; i < dateRangeList.size(); i++) {
+ // 存放一个时间点中总数
+ Map<String, Long> ipCountMap = new HashMap<String, Long>();
+ Date date = dateRangeList.get(i);
+ Long num1 = 0L;
+ Long num2 = 0L;
+ for (int j = index; j < entrance1.size(); j++) {
+ NtcEntranceReport ipInfo = entrance1.get(j);
+ if (ipInfo.getReportTime() != null) {
+ if (ipInfo.getReportTime().compareTo(date) >= 0 && (i + 1 < dateRangeList.size()
+ && ipInfo.getReportTime().compareTo(dateRangeList.get(i + 1)) < 0)) {
+ num1 = num1 + ipInfo.getSum();
+ } else {
+ index = j;
+ break;
+ }
}
}
- }
- sumList1.add(num1);
- for (int j = index; j < entrance2.size(); j++) {
- NtcEntranceReport ipInfo = entrance2.get(j);
- if (ipInfo.getReportTime() != null) {
- if (ipInfo.getReportTime().compareTo(date) >= 0 && (i + 1 < dateRangeList.size()
- && ipInfo.getReportTime().compareTo(dateRangeList.get(i + 1)) < 0)) {
- num2 = num2 + ipInfo.getSum();
- } else {
- index = j;
- break;
+ sumList1.add(num1);
+ for (int j = index; j < entrance2.size(); j++) {
+ NtcEntranceReport ipInfo = entrance2.get(j);
+ if (ipInfo.getReportTime() != null) {
+ if (ipInfo.getReportTime().compareTo(date) >= 0 && (i + 1 < dateRangeList.size()
+ && ipInfo.getReportTime().compareTo(dateRangeList.get(i + 1)) < 0)) {
+ num2 = num2 + ipInfo.getSum();
+ } else {
+ index = j;
+ break;
+ }
}
}
+ sumList2.add(num2);
}
- sumList2.add(num2);
+ // 整合 count time
+ m1.put("count", sumList1);
+ m1.put("statTime", strDateRangeList);
+ m1.put("entranceId", 1);
+ m2.put("count", sumList2);//
+ m2.put("statTime", strDateRangeList);
+ m2.put("entranceId", 2);
+ listMap.add(m1);
+ listMap.add(m2);
}
- // 整合 count time
- m1.put("count", sumList1);
- m1.put("statTime", strDateRangeList);
- m1.put("entranceId", 1);
- m2.put("count", sumList2);//
- m2.put("statTime", strDateRangeList);
- m2.put("entranceId", 2);
- listMap.add(m1);
- listMap.add(m2);
return listMap;
}
@@ -542,7 +544,7 @@ public class DashboardService extends BaseService {
Calendar calendar = Calendar.getInstance();
calendar.setTime(beginDate);
SimpleDateFormat sdf = new SimpleDateFormat("MM-dd HH:mm");
- while (calendar.getTime().compareTo(endDate) <= 0) {
+ while (calendar.getTime().compareTo(endDate) < 0) {
dateRangeList.add(calendar.getTime());
strDateRangeList.add(sdf.format(calendar.getTime()));
calendar.add(Calendar.MINUTE, 5);
@@ -1264,7 +1266,7 @@ public class DashboardService extends BaseService {
Calendar calendar = Calendar.getInstance();
calendar.setTime(startTime);
- while (calendar.getTime().compareTo(endTime) <= 0) {
+ while (calendar.getTime().compareTo(endTime) < 0) {
dateRangeList.add(calendar.getTime());
strDateRangeList.add(sdf2.format(calendar.getTime()));
calendar.add(Calendar.MINUTE, 5);
@@ -1400,47 +1402,50 @@ public class DashboardService extends BaseService {
public List<HashMap> getDomainTrans2(String begin, String end, Integer domain, Integer entranceId) {
List<TrafficHttpFocusStatistic> domainList = new ArrayList<TrafficHttpFocusStatistic>();
domainList = trafficHttpStatisticDao.getDomainTrans(entranceId, begin, end, domain);
- Date beginDate = DateUtils.parseDate(begin);
- Date endDate = DateUtils.parseDate(end);
List<HashMap> listMap = new ArrayList<HashMap>();
- List<Date> dateRangeList = new ArrayList<Date>();
- List<String> strDateRangeList = new ArrayList<String>();
- Calendar calendar = Calendar.getInstance();
- calendar.setTime(beginDate);
- SimpleDateFormat sdf = new SimpleDateFormat("MM-dd HH:mm");
- while (calendar.getTime().compareTo(endDate) <= 0) {
- dateRangeList.add(calendar.getTime());
- strDateRangeList.add(sdf.format(calendar.getTime()));
- calendar.add(Calendar.MINUTE, 5);
- }
- // 存放每个时间点的总数
- Map<String, List<Long>> ipCountListMap = new HashMap<String, List<Long>>();
- int index = 0;
- List countList = new ArrayList();
- for (int i = 0; i < dateRangeList.size(); i++) {
- // 存放一个时间点中总数
- Map<String, Long> ipCountMap = new HashMap<String, Long>();
- Date date = dateRangeList.get(i);
- Long num = 0L;
- for (int j = index; j < domainList.size(); j++) {
- TrafficHttpFocusStatistic ipInfo = domainList.get(j);
- if (ipInfo.getStatTime() != null) {
- if (ipInfo.getStatTime().compareTo(date) >= 0 && (i + 1 < dateRangeList.size()
- && ipInfo.getStatTime().compareTo(dateRangeList.get(i + 1)) < 0)) {
- num = num + ipInfo.getCount();
- } else {
- index = j;
- break;
+ if(!StringUtil.isEmpty(domainList)){
+ Date beginDate = DateUtils.parseDate(begin);
+ Date endDate = DateUtils.parseDate(end);
+
+ List<Date> dateRangeList = new ArrayList<Date>();
+ List<String> strDateRangeList = new ArrayList<String>();
+ Calendar calendar = Calendar.getInstance();
+ calendar.setTime(beginDate);
+ SimpleDateFormat sdf = new SimpleDateFormat("MM-dd HH:mm");
+ while (calendar.getTime().compareTo(endDate) < 0) {
+ dateRangeList.add(calendar.getTime());
+ strDateRangeList.add(sdf.format(calendar.getTime()));
+ calendar.add(Calendar.MINUTE, 5);
+ }
+ // 存放每个时间点的总数
+ Map<String, List<Long>> ipCountListMap = new HashMap<String, List<Long>>();
+ int index = 0;
+ List countList = new ArrayList();
+ for (int i = 0; i < dateRangeList.size(); i++) {
+ // 存放一个时间点中总数
+ Map<String, Long> ipCountMap = new HashMap<String, Long>();
+ Date date = dateRangeList.get(i);
+ Long num = 0L;
+ for (int j = index; j < domainList.size(); j++) {
+ TrafficHttpFocusStatistic ipInfo = domainList.get(j);
+ if (ipInfo.getStatTime() != null) {
+ if (ipInfo.getStatTime().compareTo(date) >= 0 && (i + 1 < dateRangeList.size()
+ && ipInfo.getStatTime().compareTo(dateRangeList.get(i + 1)) < 0)) {
+ num = num + ipInfo.getCount();
+ } else {
+ index = j;
+ break;
+ }
}
}
+ countList.add(num);
}
- countList.add(num);
+ // 整合 count time
+ HashMap ipTrafficMap = new HashMap();
+ ipTrafficMap.put("count", countList);
+ ipTrafficMap.put("statTime", strDateRangeList);
+ listMap.add(ipTrafficMap);
}
- // 整合 count time
- HashMap ipTrafficMap = new HashMap();
- ipTrafficMap.put("count", countList);
- ipTrafficMap.put("statTime", strDateRangeList);
- listMap.add(ipTrafficMap);
return listMap;
}
@@ -1479,7 +1484,7 @@ public class DashboardService extends BaseService {
Calendar calendar = Calendar.getInstance();
calendar.setTime(beginDate1);
SimpleDateFormat sdf = new SimpleDateFormat("MM-dd HH:mm");
- while (calendar.getTime().compareTo(endDate1) <= 0) {
+ while (calendar.getTime().compareTo(endDate1) < 0) {
dateRangeList.add(calendar.getTime());
strDateRangeList.add(sdf.format(calendar.getTime()));
calendar.add(Calendar.MINUTE, 5);
@@ -1580,7 +1585,7 @@ public class DashboardService extends BaseService {
Calendar calendar = Calendar.getInstance();
calendar.setTime(beginDate);
SimpleDateFormat sdf = new SimpleDateFormat("MM-dd HH:mm");
- while (calendar.getTime().compareTo(endDate)<=0) {
+ while (calendar.getTime().compareTo(endDate)<0) {
dateRangeList.add(calendar.getTime());
strDateRangeList.add(sdf.format(calendar.getTime()));
calendar.add(Calendar.MINUTE, 5);