From a9098372191b3c51995d41ee28404d1b71244d98 Mon Sep 17 00:00:00 2001 From: jiazx0107@163.com <jiazx0107@163.com> Date: 星期二, 12 十二月 2023 18:41:04 +0800 Subject: [PATCH] 提交网关心跳和设备状态2 --- src/main/java/com/fzzy/gateway/GatewayTimerScheduled.java | 78 +++++++++++++++++++++++++++++++------- 1 files changed, 63 insertions(+), 15 deletions(-) diff --git a/src/main/java/com/fzzy/gateway/GatewayTimerScheduled.java b/src/main/java/com/fzzy/gateway/GatewayTimerScheduled.java index 4bb2a3e..b29de93 100644 --- a/src/main/java/com/fzzy/gateway/GatewayTimerScheduled.java +++ b/src/main/java/com/fzzy/gateway/GatewayTimerScheduled.java @@ -1,25 +1,22 @@ package com.fzzy.gateway; import com.alibaba.fastjson.JSON; -import com.fzzy.api.data.ApiParam; -import com.fzzy.api.entity.ApiConfs; -import com.fzzy.api.service.*; -import com.fzzy.api.utils.ContextUtil; -import com.fzzy.api.utils.RedisUtil; +import com.fzzy.api.data.GatewayDeviceProtocol; +import com.fzzy.data.ConfigData; import com.fzzy.gateway.api.GatewayRemoteManager; +import com.fzzy.gateway.data.BaseReqData; import com.fzzy.gateway.data.WeatherWebDto; import com.fzzy.gateway.entity.GatewayConf; +import com.fzzy.gateway.entity.GatewayDevice; import com.fzzy.gateway.service.GatewayConfService; import com.fzzy.gateway.util.GatewayHttpUtil; import lombok.extern.slf4j.Slf4j; import org.apache.commons.lang.StringUtils; -import org.apache.commons.lang.time.DateUtils; -import org.springframework.beans.factory.annotation.Autowired; import org.springframework.scheduling.annotation.Scheduled; import org.springframework.stereotype.Component; import javax.annotation.Resource; -import java.util.Date; +import java.util.Collection; import java.util.List; /** @@ -29,7 +26,7 @@ @Component(GatewayTimerScheduled.BEAN_ID) public class GatewayTimerScheduled { - public static String DEFAULT_URL = "https://v0.yiketianqi.com/api?unescape=1&version=v61&appid={appId}&appsecret={appsecret}&cityid={cityid}"; + public static String DEFAULT_URL = "https://v1.yiketianqi.com/api?unescape=1&version=v61&appid={appId}&appsecret={appsecret}&cityid={cityid}"; public static String DEFAULT_APP_ID = "49421971"; public static String DEFAULT_APP_SECRET = "JmJE48Fv"; public static String DEFAULT_CITYID = "101270101";//鎴愰兘 @@ -39,22 +36,35 @@ @Resource private GatewayConfService confService; - @Resource private GatewayRemoteManager gatewayRemoteManager; + @Resource + private ConfigData configData; /** * <p> * 鍥哄畾鏃堕棿锛氭瘡闂撮殧10鍒嗛挓鎵ц涓�娆� */ - @Scheduled(cron = "0 0/10 * * * ? ") + @Scheduled(cron = "0 0/10 * * * ?") public void scheduled() { //缃戝叧鐨勫績璺虫墽琛� doHeartbeat(); } + + /** + * <p> + * 姣忛棿闅�3绉掓墽琛屼竴娆′簨浠� + */ + @Scheduled(cron = "0/3 * * * * ?") + public void scheduled3() { + + //鎵цHTTP鍦扮璇锋眰 + exeHttpWeightReq(); + } + /** * 姣忛棿闅�30鍒嗛挓鎵ц涓�娆� @@ -69,10 +79,22 @@ public void doWeatherExe() { try { - String url = DEFAULT_URL; - url = url.replace("{appId}", DEFAULT_APP_ID).replace("{appsecret}", DEFAULT_APP_SECRET).replace("{cityid}", DEFAULT_CITYID); + String url = configData.getWeatherPath(); - String result = GatewayHttpUtil.doGet(url, null); + if (null == url) { + url = DEFAULT_URL; + } + + url = url.replace("{appId}", DEFAULT_APP_ID).replace("{appsecret}", DEFAULT_APP_SECRET); + + if (StringUtils.isNotEmpty(configData.getCityId())) { + url = url.replace("{cityid}", configData.getCityId()); + } else { + url = url.replace("{cityid}", DEFAULT_CITYID); + } + + log.debug("------姘旇薄璇锋眰淇℃伅URL---{}", url); + String result = GatewayHttpUtil.doGet(url); if (null == result) { log.error("褰撳墠澶栫綉鑾峰彇姘旇薄淇℃伅澶辫触鈥︹��"); @@ -87,7 +109,7 @@ WeatherWebDto.contextMap.put("default", dto); - log.info("===========================绯荤粺瀹氭椂鑾疯幏鍙栨皵璞′俊鎭�===={}==================",dto); + log.info("===========================绯荤粺瀹氭椂鑾疯幏鍙栨皵璞′俊鎭�===={}==================", dto); } catch (Exception e) { @@ -112,4 +134,30 @@ } } + + /** + * 鎵ц鍦扮HTTP璇锋眰鍗忚 + */ + private void exeHttpWeightReq() { + //鑾峰彇璁惧 + Collection<GatewayDevice> list = GatewayUtils.listDeviceWeight(); + + if (null == list || list.isEmpty()) return; + + BaseReqData reqData; + for (GatewayDevice device : list) { + + if (!GatewayDeviceProtocol.DEVICE_WEIGHT_HTTP.getCode().equals(device.getSyncProtocol())) { + continue; + } + + reqData = new BaseReqData(); + reqData.setDevice(device); + reqData.setDeviceName(device.getDeviceName()); + reqData.setProductId(device.getProductId()); + reqData.setDeviceId(device.getDeviceId()); + + gatewayRemoteManager.getSyncWeightService(device.getSyncProtocol()).syncWeightInfo(reqData); + } + } } -- Gitblit v1.9.3