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 +++++++++++++++------
screen-job/src/main/java/com/moral/api/controller/PubController.java | 12 +++++-
screen-job/src/main/java/com/moral/api/service/impl/CityWeatherServiceImpl.java | 12 ++++-
3 files changed, 50 insertions(+), 18 deletions(-)
diff --git a/screen-job/src/main/java/com/moral/api/controller/PubController.java b/screen-job/src/main/java/com/moral/api/controller/PubController.java
index c11ae9a..bf074cd 100644
--- a/screen-job/src/main/java/com/moral/api/controller/PubController.java
+++ b/screen-job/src/main/java/com/moral/api/controller/PubController.java
@@ -21,7 +21,6 @@
import javax.mail.MessagingException;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
-import java.nio.file.Files;
import java.util.*;
/**
@@ -56,9 +55,11 @@
private DeviceService deviceService;
private final EmailSpringUtil emailSpringUtil;
+ private final CityWeatherForecastService cityWeatherForecastService;
- public PubController(EmailSpringUtil emailSpringUtil) {
+ public PubController(EmailSpringUtil emailSpringUtil, CityWeatherForecastService cityWeatherForecastService) {
this.emailSpringUtil = emailSpringUtil;
+ this.cityWeatherForecastService = cityWeatherForecastService;
}
@GetMapping("insertHistoryDaily")
@@ -145,6 +146,13 @@
return new ResultMessage();
}
+ @GetMapping("insertCityWeatherForecast")
+ @ApiOperation(value = "������������������������", notes = "������������������������")
+ public ResultMessage insertCityWeatherForecast() {
+ cityWeatherForecastService.insertCityWeatherForecast();
+ return new ResultMessage();
+ }
+
@GetMapping("insertHistoryMonthly")
@ApiOperation(value = "���������", notes = "���������")
public ResultMessage insertHistoryMonthly() {
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);
+
}
+
}
diff --git a/screen-job/src/main/java/com/moral/api/service/impl/CityWeatherServiceImpl.java b/screen-job/src/main/java/com/moral/api/service/impl/CityWeatherServiceImpl.java
index 2637f8f..1c19097 100644
--- a/screen-job/src/main/java/com/moral/api/service/impl/CityWeatherServiceImpl.java
+++ b/screen-job/src/main/java/com/moral/api/service/impl/CityWeatherServiceImpl.java
@@ -14,9 +14,12 @@
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.RedisTemplate;
+import org.springframework.http.client.HttpComponentsClientHttpRequestFactory;
+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;
@@ -39,8 +42,6 @@
@Autowired
private CityConfigWeatherService cityConfigWeatherService;
- @Autowired
- private RestTemplate restTemplate;
@Autowired
private RedisTemplate redisTemplate;
@@ -48,6 +49,10 @@
//������������������������������������������������������������������
@Override
public void insertCityWeather() {
+ RestTemplate restTemplate = new RestTemplate(
+ new HttpComponentsClientHttpRequestFactory()); // ������HttpClient���������GZIP
+ restTemplate.getMessageConverters().set(1,
+ new StringHttpMessageConverter(StandardCharsets.UTF_8));
//������������������
QueryWrapper<CityConfigWeather> wrapper = new QueryWrapper<>();
wrapper.select("city_code", "location_id").eq("is_delete", Constants.NOT_DELETE);
@@ -59,7 +64,8 @@
CityWeather cityWeather = new CityWeather();
Integer cityCode = cityConfigWeather.getCityCode();
Integer locationId = cityConfigWeather.getLocationId();
- Map<String, Object> data = restTemplate.getForObject("https://api.qweather.com/v7/weather/now?key=da05c6c4852d4f7aa3364a9236ee9e26&gzip=n&location={1}", Map.class, locationId);
+ //Map<String, Object> data = restTemplate.getForObject("https://api.qweather.com/v7/weather/now?key=da05c6c4852d4f7aa3364a9236ee9e26&gzip=n&location={1}", Map.class, locationId);
+ Map<String, Object> data = restTemplate.getForObject("https://devapi.qweather.com/v7/weather/now?location="+locationId+"&key=2430ab9e636c4950a686fbd84e3ccb3a", Map.class);
Map<String, Object> now = (Map<String, Object>) data.get("now");
cityWeather.setCityCode(cityCode);
//������km/h->m/s
--
Gitblit v1.8.0