2023-02-16 15:28:15 +08:00
|
|
|
|
package com.zhgd.xmgl.task;
|
|
|
|
|
|
|
2023-08-02 17:59:49 +08:00
|
|
|
|
import cn.hutool.core.bean.BeanUtil;
|
|
|
|
|
|
import cn.hutool.core.collection.CollUtil;
|
2023-02-16 15:28:15 +08:00
|
|
|
|
import com.alibaba.fastjson.JSONArray;
|
|
|
|
|
|
import com.alibaba.fastjson.JSONObject;
|
2023-08-02 17:59:49 +08:00
|
|
|
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
2023-02-16 15:28:15 +08:00
|
|
|
|
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
2023-08-02 17:59:49 +08:00
|
|
|
|
import com.gexin.fastjson.JSON;
|
2023-02-16 15:28:15 +08:00
|
|
|
|
import com.zhgd.xmgl.modules.environment.entity.DustNoiseData;
|
|
|
|
|
|
import com.zhgd.xmgl.modules.environment.entity.EnvironmentDev;
|
|
|
|
|
|
import com.zhgd.xmgl.modules.environment.mapper.DustNoiseDataMapper;
|
|
|
|
|
|
import com.zhgd.xmgl.modules.environment.mapper.EnvironmentDevMapper;
|
2023-11-22 11:27:34 +08:00
|
|
|
|
import com.zhgd.xmgl.modules.project.entity.Project;
|
|
|
|
|
|
import com.zhgd.xmgl.modules.project.mapper.ProjectMapper;
|
2023-08-02 17:59:49 +08:00
|
|
|
|
import com.zhgd.xmgl.task.dto.EnvironmentDustDataDto;
|
2023-02-16 15:28:15 +08:00
|
|
|
|
import com.zhgd.xmgl.util.EnvironmentUtils;
|
2023-08-02 17:59:49 +08:00
|
|
|
|
import com.zhgd.xmgl.util.WindDirectionUtils;
|
|
|
|
|
|
import com.zhgd.xmgl.util.XiwonUtil;
|
|
|
|
|
|
import lombok.extern.slf4j.Slf4j;
|
2023-02-16 15:28:15 +08:00
|
|
|
|
import net.javacrumbs.shedlock.core.SchedulerLock;
|
2023-08-02 17:59:49 +08:00
|
|
|
|
import org.apache.commons.lang.math.NumberUtils;
|
2023-02-16 15:28:15 +08:00
|
|
|
|
import org.apache.commons.lang3.StringUtils;
|
|
|
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
|
|
|
import org.springframework.beans.factory.annotation.Value;
|
2023-08-02 17:59:49 +08:00
|
|
|
|
import org.springframework.http.HttpStatus;
|
2023-02-16 15:28:15 +08:00
|
|
|
|
import org.springframework.scheduling.annotation.Scheduled;
|
|
|
|
|
|
import org.springframework.stereotype.Component;
|
2024-03-08 19:15:47 +08:00
|
|
|
|
import org.springframework.web.bind.annotation.GetMapping;
|
2024-03-12 17:26:22 +08:00
|
|
|
|
import org.springframework.web.bind.annotation.RequestMapping;
|
2024-03-08 19:15:47 +08:00
|
|
|
|
import org.springframework.web.bind.annotation.RestController;
|
2023-02-16 15:28:15 +08:00
|
|
|
|
|
2023-08-02 17:59:49 +08:00
|
|
|
|
import javax.annotation.Resource;
|
2023-02-16 15:28:15 +08:00
|
|
|
|
import java.text.DecimalFormat;
|
|
|
|
|
|
import java.text.SimpleDateFormat;
|
2023-08-02 17:59:49 +08:00
|
|
|
|
import java.util.*;
|
|
|
|
|
|
import java.util.concurrent.CompletableFuture;
|
2023-02-16 15:28:15 +08:00
|
|
|
|
import java.util.stream.Collectors;
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* @program: wisdomSite
|
|
|
|
|
|
* @description: 环境设备实时数据
|
|
|
|
|
|
* @author: Mr.Peng
|
|
|
|
|
|
* @create: 2021-07-12 13:41
|
|
|
|
|
|
**/
|
2023-08-02 17:59:49 +08:00
|
|
|
|
@Slf4j
|
2024-03-12 17:26:22 +08:00
|
|
|
|
@RestController
|
|
|
|
|
|
@RequestMapping("/xmgl/task")
|
2023-02-16 15:28:15 +08:00
|
|
|
|
public class EnvironmentDevTask {
|
|
|
|
|
|
@Autowired
|
|
|
|
|
|
private EnvironmentDevMapper environmentDevMapper;
|
|
|
|
|
|
@Autowired
|
|
|
|
|
|
private DustNoiseDataMapper dustNoiseDataMapper;
|
|
|
|
|
|
|
|
|
|
|
|
@Value("${isGetEnvironmentData}")
|
|
|
|
|
|
private boolean isGetEnvironmentData;
|
2023-11-22 11:27:34 +08:00
|
|
|
|
@Autowired
|
|
|
|
|
|
private ProjectMapper projectMapper;
|
2023-08-02 17:59:49 +08:00
|
|
|
|
|
|
|
|
|
|
@Resource
|
|
|
|
|
|
private XiwonUtil xiwonUtil;
|
|
|
|
|
|
|
2023-02-16 15:28:15 +08:00
|
|
|
|
/**
|
|
|
|
|
|
* 定时调用外部接口拉取设备实时数据
|
|
|
|
|
|
*/
|
|
|
|
|
|
@Scheduled(cron = "0 0/2 * * * ?")
|
2023-08-02 17:59:49 +08:00
|
|
|
|
@SchedulerLock(name = "getEnvironmentData", lockAtMostFor = 1000 * 60 * 2, lockAtLeastFor = 1000 * 60 * 1)
|
|
|
|
|
|
public void getStandardData() {
|
2023-02-16 15:28:15 +08:00
|
|
|
|
if (isGetEnvironmentData) {
|
|
|
|
|
|
try {
|
|
|
|
|
|
QueryWrapper<EnvironmentDev> queryWrapper = new QueryWrapper<>();
|
|
|
|
|
|
List<EnvironmentDev> list = environmentDevMapper.selectList(queryWrapper);
|
|
|
|
|
|
if (list != null && list.size() > 0) {
|
|
|
|
|
|
JSONArray array = EnvironmentUtils.getDeviceData("");
|
|
|
|
|
|
for (EnvironmentDev dev : list) {
|
|
|
|
|
|
List<Double> pm10List = new ArrayList<>();
|
|
|
|
|
|
List<Double> pm25List = new ArrayList<>();
|
|
|
|
|
|
if (array != null && array.size() > 0) {
|
|
|
|
|
|
for (int i = 0; i < array.size(); i++) {
|
|
|
|
|
|
JSONObject obj = array.getJSONObject(i);
|
2023-08-02 17:59:49 +08:00
|
|
|
|
if (dev.getDeviceId().equals(obj.getString("deviceAddr"))) {
|
2023-02-16 15:28:15 +08:00
|
|
|
|
//判断设备是否在线
|
|
|
|
|
|
if ("2".equals(obj.getString("deviceStatus"))) {
|
|
|
|
|
|
JSONArray jsonArray = obj.getJSONArray("realTimeData");
|
|
|
|
|
|
if (jsonArray != null && jsonArray.size() > 0) {
|
|
|
|
|
|
for (int a = 0; a < jsonArray.size(); a++) {
|
|
|
|
|
|
JSONObject obj2 = jsonArray.getJSONObject(a);
|
|
|
|
|
|
if (obj2.getString("dataName").indexOf("PM10") >= 0) {
|
2023-08-02 17:59:49 +08:00
|
|
|
|
if (StringUtils.isNotEmpty(obj2.getString("dataValue")) && obj2.getDouble("dataValue") != 0d) {
|
2023-02-16 15:28:15 +08:00
|
|
|
|
pm10List.add(Double.valueOf(obj2.getString("dataValue")));
|
|
|
|
|
|
}
|
|
|
|
|
|
} else if (obj2.getString("dataName").indexOf("PM2.5") >= 0) {
|
2023-08-02 17:59:49 +08:00
|
|
|
|
if (StringUtils.isNotEmpty(obj2.getString("dataValue")) && obj2.getDouble("dataValue") != 0d) {
|
2023-02-16 15:28:15 +08:00
|
|
|
|
pm25List.add(Double.valueOf(obj2.getString("dataValue")));
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
//没有数据不插入
|
|
|
|
|
|
if (pm10List.size() > 0 || pm10List.size() > 0) {
|
|
|
|
|
|
DecimalFormat df = new DecimalFormat("#.00");
|
|
|
|
|
|
DustNoiseData dustNoiseData = new DustNoiseData();
|
|
|
|
|
|
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
|
|
|
|
|
|
dustNoiseData.setUploadDate(sdf.format(new Date()));
|
|
|
|
|
|
dustNoiseData.setProjectSn(dev.getProjectSn());
|
|
|
|
|
|
dustNoiseData.setDeviceId(dev.getDeviceId());
|
|
|
|
|
|
if (pm10List.size() > 0) {
|
|
|
|
|
|
//计算pm10平均值
|
|
|
|
|
|
double avg = pm10List.stream().collect(Collectors.averagingDouble(n -> n));
|
2023-08-02 17:59:49 +08:00
|
|
|
|
dustNoiseData.setPm10(Double.valueOf(df.format(avg)));
|
2023-02-16 15:28:15 +08:00
|
|
|
|
}
|
|
|
|
|
|
if (pm25List.size() > 0) {
|
|
|
|
|
|
//计算pm2.5平均值
|
|
|
|
|
|
double avg = pm25List.stream().collect(Collectors.averagingDouble(n -> n));
|
2023-08-02 17:59:49 +08:00
|
|
|
|
dustNoiseData.setPm25(Double.valueOf(df.format(avg)));
|
2023-02-16 15:28:15 +08:00
|
|
|
|
}
|
|
|
|
|
|
dustNoiseDataMapper.insert(dustNoiseData);
|
|
|
|
|
|
EnvironmentDev tempEnvironmentDev = new EnvironmentDev();
|
|
|
|
|
|
tempEnvironmentDev.setId(dev.getId());
|
|
|
|
|
|
tempEnvironmentDev.setRealTime(new Date());
|
|
|
|
|
|
environmentDevMapper.updateById(tempEnvironmentDev);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
2023-08-02 17:59:49 +08:00
|
|
|
|
} catch (Exception e) {
|
2023-02-16 15:28:15 +08:00
|
|
|
|
e.printStackTrace();
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
2023-08-02 17:59:49 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* 获取扬尘数据(携稳) 每5分钟触发任务
|
|
|
|
|
|
*/
|
|
|
|
|
|
@SchedulerLock(name = "getEnvironmentDustData", lockAtMostFor = 1000 * 60 * 5, lockAtLeastFor = 1000 * 60 * 3)
|
|
|
|
|
|
@Scheduled(cron = "0 0/5 * * * ?")
|
2024-03-08 19:15:47 +08:00
|
|
|
|
@GetMapping("dustData")
|
2023-08-02 17:59:49 +08:00
|
|
|
|
public void getEnvironmentDustData() {
|
2023-11-22 11:27:34 +08:00
|
|
|
|
log.info("获取扬尘数据(携稳)开始任务");
|
|
|
|
|
|
List<Project> projects = projectMapper.selectList(new LambdaQueryWrapper<Project>()
|
|
|
|
|
|
.isNotNull(Project::getXiwonAppId)
|
|
|
|
|
|
.isNotNull(Project::getXiwonAppSecret)
|
|
|
|
|
|
);
|
|
|
|
|
|
for (Project project : projects) {
|
|
|
|
|
|
// 获取设备列表
|
|
|
|
|
|
List<EnvironmentDev> devList = environmentDevMapper.selectList(new LambdaQueryWrapper<EnvironmentDev>()
|
|
|
|
|
|
.eq(EnvironmentDev::getProjectSn, project.getProjectSn()));
|
2023-08-02 17:59:49 +08:00
|
|
|
|
devList.forEach(dev -> CompletableFuture.runAsync(() -> {
|
2023-11-22 11:27:34 +08:00
|
|
|
|
doGetEnvironmentDustData(dev, project);
|
2023-08-02 17:59:49 +08:00
|
|
|
|
}).exceptionally(throwable -> {
|
|
|
|
|
|
log.error("err", throwable);
|
|
|
|
|
|
return null;
|
|
|
|
|
|
})
|
|
|
|
|
|
);
|
|
|
|
|
|
}
|
2023-11-22 11:27:34 +08:00
|
|
|
|
|
2023-08-02 17:59:49 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2023-11-22 11:27:34 +08:00
|
|
|
|
private void doGetEnvironmentDustData(EnvironmentDev dev, Project project) {
|
2023-08-02 17:59:49 +08:00
|
|
|
|
// 设备sn
|
|
|
|
|
|
String devSn = dev.getDeviceId();
|
|
|
|
|
|
log.info("doGetEnvironmentDustData设备sn:{}", devSn);
|
|
|
|
|
|
DustNoiseData newestData = dustNoiseDataMapper.selectOne(new LambdaQueryWrapper<DustNoiseData>().eq(DustNoiseData::getDeviceId, devSn).orderByDesc(DustNoiseData::getXiewenId).last("limit 1"));
|
|
|
|
|
|
// 请求参数
|
|
|
|
|
|
Map<String, Object> map = new HashMap<>(4);
|
|
|
|
|
|
map.put("pageSize", "10");
|
|
|
|
|
|
map.put("pageNum", "1");
|
2024-01-20 10:18:46 +08:00
|
|
|
|
JSONObject realTimeData = xiwonUtil.postForm("/dust/realTimeData", project.getXiwonAppId(), project.getXiwonAppSecret(), map, JSONObject.class, (() -> {
|
2023-08-02 17:59:49 +08:00
|
|
|
|
map.put("deviceSn", devSn);
|
|
|
|
|
|
if (newestData != null && newestData.getXiewenId() != null) {
|
|
|
|
|
|
map.put("dataId", newestData.getXiewenId());
|
|
|
|
|
|
}
|
|
|
|
|
|
return map;
|
|
|
|
|
|
}));
|
|
|
|
|
|
log.info("携稳接口响应数据(扬尘):devSn:{},rs:{}", devSn, JSON.toJSONString(realTimeData));
|
|
|
|
|
|
Integer code = realTimeData.getInteger("code");
|
|
|
|
|
|
// code校验是否成功请求
|
|
|
|
|
|
if (code == HttpStatus.OK.value()) {
|
|
|
|
|
|
JSONArray dataArray = realTimeData.getJSONArray("data");
|
|
|
|
|
|
if (CollUtil.isNotEmpty(dataArray)) {
|
|
|
|
|
|
// 解析请求到的参数,保存到我们的数据库
|
|
|
|
|
|
for (Object o : dataArray) {
|
|
|
|
|
|
EnvironmentDustDataDto dto = BeanUtil.toBean(o, EnvironmentDustDataDto.class);
|
|
|
|
|
|
DustNoiseData data = new DustNoiseData();
|
|
|
|
|
|
data.setProjectSn(dev.getProjectSn());
|
|
|
|
|
|
data.setDeviceId(devSn);
|
|
|
|
|
|
data.setUploadDate(dto.getTime());
|
|
|
|
|
|
data.setPm10(dto.getPmTen() != null ? Double.valueOf(dto.getPmTen()) : null);
|
|
|
|
|
|
data.setPm25(dto.getPmTah() != null ? Double.valueOf(dto.getPmTah()) : null);
|
|
|
|
|
|
data.setNoise(dto.getNoise() != null ? Double.valueOf(dto.getNoise()) : null);
|
2024-03-12 16:46:58 +08:00
|
|
|
|
if (Objects.equals(project.getProjectSn(), "EEDD6F22AA774F2BBF6C8BE26C6E9953")) {
|
|
|
|
|
|
data.setTsp(13D);
|
|
|
|
|
|
} else {
|
|
|
|
|
|
data.setTsp(dto.getTsp() != null ? Double.valueOf(dto.getTsp()) : null);
|
|
|
|
|
|
}
|
2023-08-02 17:59:49 +08:00
|
|
|
|
data.setTemperature(dto.getTemperature() != null ? Double.valueOf(dto.getTemperature()) : null);
|
|
|
|
|
|
data.setHumidity(dto.getHumidity() != null ? Double.valueOf(dto.getHumidity()) : null);
|
|
|
|
|
|
data.setWindspeed(dto.getWindSpeed() != null ? Double.valueOf(dto.getWindSpeed()) : null);
|
|
|
|
|
|
data.setWinddirection(dto.getWindDirection() != null ? WindDirectionUtils.getWindDirectionName(String.valueOf(dto.getWindDirection())) : null);
|
|
|
|
|
|
data.setPressure(StringUtils.isNotBlank(dto.getPressure()) ? NumberUtils.toDouble(dto.getPressure()) : null);
|
|
|
|
|
|
data.setXiewenId(Long.valueOf(dto.getId()));
|
|
|
|
|
|
dustNoiseDataMapper.insert(data);
|
2023-09-08 16:35:35 +08:00
|
|
|
|
environmentDevMapper.updateEnvironmentDevRealTimeById(dev.getId());
|
2023-08-02 17:59:49 +08:00
|
|
|
|
}
|
|
|
|
|
|
} else {
|
|
|
|
|
|
log.info("设备sn:{},当前无数据!", devSn);
|
|
|
|
|
|
}
|
|
|
|
|
|
} else {
|
|
|
|
|
|
log.error("设备sn:{},请求失败!当前code:{},msg:{}", devSn, code, realTimeData.getString("msg"));
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
2023-02-16 15:28:15 +08:00
|
|
|
|
}
|