Compare commits
No commits in common. "8b696e1ce2c1b02f422621e05e6a6ca14d259302" and "7174c59e8e74ceadad5e41d875d96b1f984e7805" have entirely different histories.
8b696e1ce2
...
7174c59e8e
@ -1,243 +0,0 @@
|
|||||||
package cn.iocoder.yudao.module.hiking;
|
|
||||||
|
|
||||||
import cn.iocoder.yudao.framework.common.util.object.BeanUtils;
|
|
||||||
import cn.iocoder.yudao.module.hiking.controller.admin.camera.vo.CameraSaveReqVO;
|
|
||||||
import cn.iocoder.yudao.module.hiking.controller.admin.region.vo.RegionSaveReqVO;
|
|
||||||
import cn.iocoder.yudao.module.hiking.dal.dataobject.camera.CameraDO;
|
|
||||||
import cn.iocoder.yudao.module.hiking.service.camera.CameraService;
|
|
||||||
import com.fasterxml.jackson.core.JsonProcessingException;
|
|
||||||
import com.fasterxml.jackson.databind.JsonNode;
|
|
||||||
import com.fasterxml.jackson.databind.ObjectMapper;
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.data.redis.core.RedisTemplate;
|
|
||||||
import org.springframework.util.StringUtils;
|
|
||||||
import org.springframework.web.bind.annotation.GetMapping;
|
|
||||||
import org.springframework.web.bind.annotation.RestController;
|
|
||||||
|
|
||||||
import javax.annotation.Resource;
|
|
||||||
import java.time.LocalDateTime;
|
|
||||||
import java.time.OffsetDateTime;
|
|
||||||
import java.time.format.DateTimeFormatter;
|
|
||||||
import java.util.Iterator;
|
|
||||||
import java.util.concurrent.TimeUnit;
|
|
||||||
|
|
||||||
|
|
||||||
@RestController
|
|
||||||
public class GetCameraInfoUtil {
|
|
||||||
@Autowired
|
|
||||||
private RedisTemplate<String, String> redisTemplate;
|
|
||||||
@Resource
|
|
||||||
private CameraService cameraService;
|
|
||||||
private static final String ACCESS_TOKEN_KEY = "hikingAPI:access_token";
|
|
||||||
|
|
||||||
|
|
||||||
public String getAccessToken() {
|
|
||||||
// 检查 Redis 中是否有 access_token
|
|
||||||
String accessToken = redisTemplate.opsForValue().get(ACCESS_TOKEN_KEY);
|
|
||||||
if (!StringUtils.isEmpty(accessToken)) {
|
|
||||||
System.out.println("使用缓存的token:" + accessToken);
|
|
||||||
return accessToken; // 如果存在则直接返回
|
|
||||||
}
|
|
||||||
|
|
||||||
// 如果没有,调用 API 获取并存入 Redis
|
|
||||||
System.out.println("获取新的token");
|
|
||||||
String accessTokenUrlResp = IntegrationURL.getAccessTokenURL();
|
|
||||||
try {
|
|
||||||
ObjectMapper objectMapper = new ObjectMapper();
|
|
||||||
JsonNode jsonNode = objectMapper.readTree(accessTokenUrlResp);
|
|
||||||
accessToken = jsonNode.get("access_token").asText();
|
|
||||||
|
|
||||||
// 将 access_token 存入 Redis,设置过期时间为 11 小时(有效期12小时)
|
|
||||||
redisTemplate.opsForValue().set(ACCESS_TOKEN_KEY, accessToken, 11, TimeUnit.HOURS);
|
|
||||||
} catch (Exception e) {
|
|
||||||
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
return accessToken;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void deleteAccessToken() {
|
|
||||||
redisTemplate.delete(ACCESS_TOKEN_KEY);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
public Boolean checkToken(String result) {
|
|
||||||
try {
|
|
||||||
ObjectMapper objectMapper = new ObjectMapper();
|
|
||||||
JsonNode jsonNode = objectMapper.readTree(result);
|
|
||||||
String code = jsonNode.path("code").asText();
|
|
||||||
if ("0x02401007".equals(code)) {
|
|
||||||
System.out.println("token失效,重新获取");
|
|
||||||
deleteAccessToken();
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
} catch (JsonProcessingException e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
@GetMapping("/getCameraListToDB")
|
|
||||||
public void getCameraListToDB() {
|
|
||||||
try {
|
|
||||||
// 总记录数
|
|
||||||
int total = 0;
|
|
||||||
JsonNode jsonNode;
|
|
||||||
JsonNode cameraDataList;
|
|
||||||
// 查询有几条记录
|
|
||||||
// String cameraListPageURL = IntegrationURL.getCameraResourceURL(1, 1, getAccessToken());
|
|
||||||
// if (!checkToken(cameraListPageURL)) {
|
|
||||||
// cameraListPageURL = IntegrationURL.getCameraResourceURL(1, 1, getAccessToken());
|
|
||||||
// }
|
|
||||||
String cameraListPageURL = " {\n" +
|
|
||||||
" \"code\": \"0\", \n" +
|
|
||||||
" \"msg\": \"success\", \n" +
|
|
||||||
" \"data\": {\n" +
|
|
||||||
" \"total\": 13, \n" +
|
|
||||||
" \"pageNo\": 1, \n" +
|
|
||||||
" \"pageSize\": 1, \n" +
|
|
||||||
" \"list\": [\n" +
|
|
||||||
" {\n" +
|
|
||||||
" \"altitude\": null, \n" +
|
|
||||||
" \"cameraIndexCode\": \"eddf8458f74d42e9bf4ecfc752dba146\", \n" +
|
|
||||||
" \"cameraName\": \"3层吉米后厨入口\", \n" +
|
|
||||||
" \"cameraType\": 0, \n" +
|
|
||||||
" \"cameraTypeName\": \"枪机\", \n" +
|
|
||||||
" \"capabilitySet\": \"io,event_io,event_ias,event_rule,event_heat,record,net,event_face,vss,ptz,status,maintenance,event_device\", \n" +
|
|
||||||
" \"capabilitySetName\": null, \n" +
|
|
||||||
" \"intelligentSet\": null, \n" +
|
|
||||||
" \"intelligentSetName\": null, \n" +
|
|
||||||
" \"channelNo\": \"33\", \n" +
|
|
||||||
" \"channelType\": \"digital\", \n" +
|
|
||||||
" \"channelTypeName\": \"数字通道\", \n" +
|
|
||||||
" \"createTime\": \"2018-09-15T11:14:27.812+08:00\", \n" +
|
|
||||||
" \"encodeDevIndexCode\": \"1d3d5c26e6174cf1aa452f57cac91879\", \n" +
|
|
||||||
" \"encodeDevResourceType\": null, \n" +
|
|
||||||
" \"encodeDevResourceTypeName\": null, \n" +
|
|
||||||
" \"gbIndexCode\": null, \n" +
|
|
||||||
" \"installLocation\": null, \n" +
|
|
||||||
" \"keyBoardCode\": null, \n" +
|
|
||||||
" \"latitude\": null, \n" +
|
|
||||||
" \"longitude\": null, \n" +
|
|
||||||
" \"pixel\": null, \n" +
|
|
||||||
" \"ptz\": null, \n" +
|
|
||||||
" \"ptzName\": null, \n" +
|
|
||||||
" \"ptzController\": null, \n" +
|
|
||||||
" \"ptzControllerName\": null, \n" +
|
|
||||||
" \"recordLocation\": null, \n" +
|
|
||||||
" \"recordLocationName\": null, \n" +
|
|
||||||
" \"regionIndexCode\": \"2feadc43-ffef-464b-a2e2-b146a02de5ba\", \n" +
|
|
||||||
" \"status\": null, \n" +
|
|
||||||
" \"statusName\": null, \n" +
|
|
||||||
" \"transType\": 1, \n" +
|
|
||||||
" \"transTypeName\": \"TCP\", \n" +
|
|
||||||
" \"treatyType\": null, \n" +
|
|
||||||
" \"treatyTypeName\": null, \n" +
|
|
||||||
" \"viewshed\": null, \n" +
|
|
||||||
" \"updateTime\": \"2018-09-15T11:19:48.973+08:00\"\n" +
|
|
||||||
" }\n" +
|
|
||||||
" ]\n" +
|
|
||||||
" }\n" +
|
|
||||||
"}\n";
|
|
||||||
ObjectMapper objectMapper = new ObjectMapper();
|
|
||||||
jsonNode = objectMapper.readTree(cameraListPageURL);
|
|
||||||
// total = jsonNode.path("data").path("total").asInt();
|
|
||||||
total = 1;
|
|
||||||
|
|
||||||
JsonNode cameraNode;
|
|
||||||
// 查询所有记录的cameraIndexCode并保存
|
|
||||||
for (int i = 1; i <= (total / 100) + 1; i++) {
|
|
||||||
System.out.println("开始第" + i + "次查询");
|
|
||||||
// cameraListPageURL = IntegrationURL.getCameraResourceURL(i, 100, getAccessToken());
|
|
||||||
jsonNode = objectMapper.readTree(cameraListPageURL);
|
|
||||||
cameraDataList = jsonNode.path("data").path("list");
|
|
||||||
System.out.println(cameraDataList);
|
|
||||||
Iterator<JsonNode> elements2 = cameraDataList.elements();
|
|
||||||
while (elements2.hasNext()) {
|
|
||||||
CameraDO cameraDO = new CameraDO();
|
|
||||||
cameraNode = elements2.next();
|
|
||||||
System.out.println("cameraNode:"+cameraNode);
|
|
||||||
cameraDO.setAltitude(cameraNode.path("altitude").asText());
|
|
||||||
cameraDO.setCameraIndexCode(cameraNode.path("cameraIndexCode").asText());
|
|
||||||
cameraDO.setCameraName(cameraNode.path("cameraName").asText());
|
|
||||||
cameraDO.setCameraType(cameraNode.path("cameraType").asInt());
|
|
||||||
cameraDO.setCameraTypeName(cameraNode.path("cameraTypeName").asText());
|
|
||||||
cameraDO.setCapabilitySet(cameraNode.path("capabilitySet").asText());
|
|
||||||
cameraDO.setCapabilitySetName(cameraNode.path("capabilitySetName").asText());
|
|
||||||
cameraDO.setIntelligentSet(cameraNode.path("intelligentSet").asText());
|
|
||||||
cameraDO.setIntelligentSetName(cameraNode.path("intelligentSetName").asText());
|
|
||||||
cameraDO.setChannelNo(cameraNode.path("channelNo").asText());
|
|
||||||
cameraDO.setChannelType(cameraNode.path("channelType").asText());
|
|
||||||
cameraDO.setChannelTypeName(cameraNode.path("channelTypeName").asText());
|
|
||||||
cameraDO.setCreateTime(dateParse(cameraNode.path("createTime").asText()));
|
|
||||||
cameraDO.setEncodeDevIndexCode(cameraNode.path("encodeDevIndexCode").asText());
|
|
||||||
cameraDO.setEncodeDevResourceType(cameraNode.path("encodeDevResourceType").asText());
|
|
||||||
cameraDO.setEncodeDevResourceTypeName(cameraNode.path("encodeDevResourceTypeName").asText());
|
|
||||||
cameraDO.setGbIndexCode(cameraNode.path("gbIndexCode").asText());
|
|
||||||
cameraDO.setInstallLocation(cameraNode.path("installLocation").asText());
|
|
||||||
cameraDO.setKeyBoardCode(cameraNode.path("keyBoardCode").asText());
|
|
||||||
cameraDO.setLatitude(cameraNode.path("latitude").asText());
|
|
||||||
cameraDO.setLongitude(cameraNode.path("longitude").asText());
|
|
||||||
cameraDO.setPixel(cameraNode.path("pixel").asText());
|
|
||||||
cameraDO.setPtz(cameraNode.path("ptz").asText());
|
|
||||||
cameraDO.setPtzName(cameraNode.path("ptzName").asText());
|
|
||||||
cameraDO.setPtzController(cameraNode.path("ptzController").asText());
|
|
||||||
cameraDO.setPtzControllerName(cameraNode.path("ptzControllerName").asText());
|
|
||||||
cameraDO.setRecordLocation(cameraNode.path("recordLocation").asText());
|
|
||||||
cameraDO.setRecordLocationName(cameraNode.path("recordLocationName").asText());
|
|
||||||
cameraDO.setRegionIndexCode(cameraNode.path("regionIndexCode").asText());
|
|
||||||
cameraDO.setStatus(cameraNode.path("status").asText());
|
|
||||||
cameraDO.setStatusName(cameraNode.path("statusName").asText());
|
|
||||||
cameraDO.setTransType(cameraNode.path("transType").asInt());
|
|
||||||
cameraDO.setTransTypeName(cameraNode.path("transTypeName").asText());
|
|
||||||
cameraDO.setTreatyType(cameraNode.path("treatyType").asText());
|
|
||||||
cameraDO.setTreatyTypeName(cameraNode.path("treatyTypeName").asText());
|
|
||||||
cameraDO.setViewshed(cameraNode.path("viewshed").asText());
|
|
||||||
cameraDO.setUpdateTime(dateParse(cameraNode.path("updateTime").asText()));
|
|
||||||
|
|
||||||
// 查询数据库中是否已有数据
|
|
||||||
CameraDO dbCameraData = cameraService.selectByCameraIndexCode(cameraDO.getCameraIndexCode());
|
|
||||||
System.out.println("dbCameraData: " + dbCameraData);
|
|
||||||
System.out.println(cameraDO);
|
|
||||||
CameraSaveReqVO cameraSaveReqVO = BeanUtils.toBean(cameraDO, CameraSaveReqVO.class);
|
|
||||||
// 如果数据库中有记录且数据不一致,执行更新操作
|
|
||||||
if (dbCameraData != null && !cameraDO.getUpdateTime().equals(dbCameraData.getUpdateTime())) {
|
|
||||||
// 进行更新操作
|
|
||||||
cameraService.updateCameraCheckByCameraIndexCode(cameraSaveReqVO);
|
|
||||||
System.out.println("更新了" + cameraDO.getCameraIndexCode() + "的数据");
|
|
||||||
} else if (dbCameraData == null) {
|
|
||||||
// 如果数据库中没有记录,则插入新数据
|
|
||||||
cameraService.createCamera(cameraSaveReqVO);
|
|
||||||
System.out.println("插入了" + cameraDO.getCameraIndexCode() + "的数据");
|
|
||||||
} else {
|
|
||||||
System.out.println("无需更新" + cameraDO.getCameraIndexCode() + "的数据");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} catch (
|
|
||||||
Exception e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
private LocalDateTime dateParse(String dateStr) {
|
|
||||||
String dateString = dateStr;
|
|
||||||
// 通过正则调整时区格式
|
|
||||||
// 这次确保只有一位数字时区后缀 +0800 被替换为 +08:00
|
|
||||||
if (dateString.matches(".*\\+\\d{4}$")) {
|
|
||||||
dateString = dateString.replaceAll("(\\+\\d{2})(\\d{2})$", "$1:$2");
|
|
||||||
}
|
|
||||||
|
|
||||||
// 定义一个日期格式化器,包括时区信息
|
|
||||||
DateTimeFormatter formatter = DateTimeFormatter.ISO_OFFSET_DATE_TIME;
|
|
||||||
|
|
||||||
// 解析带有时区的字符串
|
|
||||||
OffsetDateTime offsetDateTime = OffsetDateTime.parse(dateString, formatter);
|
|
||||||
|
|
||||||
// 转换为 LocalDateTime
|
|
||||||
LocalDateTime localDateTime = offsetDateTime.toLocalDateTime();
|
|
||||||
|
|
||||||
return localDateTime;
|
|
||||||
}
|
|
||||||
}
|
|
Loading…
x
Reference in New Issue
Block a user