From 247e9203e92423930bee311af18c355400a9b57b Mon Sep 17 00:00:00 2001
From: cjl <909710561@qq.com>
Date: Mon, 01 Apr 2024 10:01:55 +0800
Subject: [PATCH] fix:和风数据修复

---
 screen-job/src/main/java/com/moral/api/service/impl/CityWeatherForecastServiceImpl.java |   44 +++++++++++++++++++++++++++++++-------------
 1 files changed, 31 insertions(+), 13 deletions(-)

diff --git a/screen-job/src/main/java/com/moral/api/service/impl/CityWeatherForecastServiceImpl.java b/screen-job/src/main/java/com/moral/api/service/impl/CityWeatherForecastServiceImpl.java
index b8d827f..8f9cb21 100644
--- a/screen-job/src/main/java/com/moral/api/service/impl/CityWeatherForecastServiceImpl.java
+++ b/screen-job/src/main/java/com/moral/api/service/impl/CityWeatherForecastServiceImpl.java
@@ -1,5 +1,6 @@
 package com.moral.api.service.impl;
 
+import com.alibaba.fastjson.JSON;
 import com.alibaba.fastjson.JSONObject;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.moral.api.entity.CityConfigWeatherForecast;
@@ -12,9 +13,14 @@
 import com.moral.util.DateUtils;
 
 import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.http.*;
+import org.springframework.http.client.HttpComponentsClientHttpRequestFactory;
+import org.springframework.http.converter.HttpMessageConverter;
+import org.springframework.http.converter.StringHttpMessageConverter;
 import org.springframework.stereotype.Service;
 import org.springframework.web.client.RestTemplate;
 
+import java.nio.charset.StandardCharsets;
 import java.util.ArrayList;
 import java.util.Date;
 import java.util.List;
@@ -35,16 +41,17 @@
     private CityConfigWeatherForecastService cityConfigWeatherForecastService;
 
     @Autowired
-    private RestTemplate restTemplate;
-
-    @Autowired
     private CityWeatherForecastMapper cityWeatherForecastMapper;
 
 
     //���������������������������������������������������������������������������������72������������������
     @Override
     public void insertCityWeatherForecast() {
-        Date nextDay = DateUtils.addDays(new Date(), 1);
+        RestTemplate restTemplate = new RestTemplate(
+                new HttpComponentsClientHttpRequestFactory()); // ������HttpClient���������GZIP
+        restTemplate.getMessageConverters().set(1,
+                new StringHttpMessageConverter(StandardCharsets.UTF_8));
+        Date nextDay = DateUtils.addDays(new Date(), 0);
         String nextTime = DateUtils.dateToDateString(nextDay, DateUtils.yyyy_MM_dd_EN);
         //������������������
         QueryWrapper<CityConfigWeatherForecast> wrapper = new QueryWrapper<>();
@@ -56,33 +63,44 @@
         for (CityConfigWeatherForecast cityConfigWeatherForecast : list) {
             Integer cityCode = cityConfigWeatherForecast.getCityCode();
             Integer locationId = cityConfigWeatherForecast.getLocationId();
-            Map<String, Object> data = restTemplate.getForObject("https://api.qweather.com/v7/weather/72h?key=da05c6c4852d4f7aa3364a9236ee9e26&gzip=n&location={1}", Map.class, locationId);
+            //Map<String, Object> data = restTemplate.getForObject("https://api.qweather.com/v7/weather/72h?key=da05c6c4852d4f7aa3364a9236ee9e26&gzip=n&location={1}", Map.class, locationId);
+            Map<String, Object> data = restTemplate.getForObject("https://devapi.qweather.com/v7/weather/24h?location="+locationId+"&key=2430ab9e636c4950a686fbd84e3ccb3a", Map.class);
+            //Map<String, Object> data = restTemplate.getForObject(url,Map.class);
             List<Map<String, Object>> hourly = (List<Map<String, Object>>) data.get("hourly");
             for (Map<String, Object> hourlyMap : hourly) {
                 String fxTime = hourlyMap.get("fxTime").toString();
                 String dayTime = fxTime.split("T")[0];
-                if (dayTime.equals(nextTime)) {
+                //if (dayTime.equals(nextTime)) {
                     String hourTime = fxTime.substring(0, 17).replaceAll("T", " ");
                     CityWeatherForecast cityWeatherForecast = new CityWeatherForecast();
                     cityWeatherForecast.setCityCode(cityCode);
                     cityWeatherForecast.setTime(DateUtils.getDate(hourTime, DateUtils.yyyy_MM_dd_HH_EN));
                     cityWeatherForecast.setValue(JSONObject.toJSONString(hourlyMap));
                     cityWeatherForecasts.add(cityWeatherForecast);
-                }
+                //}
             }
         }
         cityWeatherForecastMapper.insertCityWeatherForecast(cityWeatherForecasts);
     }
 
     public static void main(String[] args) {
-        String time = "20221231";
-        long currentMils = DateUtils.getDate(time, DateUtils.yyyyMMdd_EN).getTime();
+        String url = "https://devapi.qweather.com/v7/weather/24h?location=101010100&key=2430ab9e636c4950a686fbd84e3ccb3a"; //���������������������������
+        RestTemplate restTemplate = new RestTemplate(
+                new HttpComponentsClientHttpRequestFactory()); // ������HttpClient���������GZIP
+        restTemplate.getMessageConverters().set(1,
+                new StringHttpMessageConverter(StandardCharsets.UTF_8));
+        Map<String, Object> data = restTemplate.getForObject(url,Map.class);
+        List<Map<String, Object>> hourly = (List<Map<String, Object>>) data.get("hourly");
+        int i = 0;
 
-        long startMils = DateUtils.getDate("2022", DateUtils.yyyy).getTime();
-        long mss = currentMils - startMils;
-        long days = mss / (1000 * 60 * 60 * 24);
-        System.out.println(days + 1);
+
+
+
+        //String url = "https://devapi.qweather.com/v7/weather/24h?location=101010100&key=2430ab9e636c4950a686fbd84e3ccb3a"; //���������������������������
+      //  String response = restTemplate.getForObject(url,String.class);
+
 
 
     }
+
 }

--
Gitblit v1.8.0