苗情设备实时数据
This commit is contained in:
parent
a97ef406a5
commit
b41daba731
@ -0,0 +1,148 @@
|
||||
package com.fastbee.deviceData.api.devlink.service;
|
||||
|
||||
import cn.hutool.http.HttpUtil;
|
||||
import cn.hutool.json.JSONArray;
|
||||
import cn.hutool.json.JSONObject;
|
||||
import cn.hutool.json.JSONUtil;
|
||||
import com.fastbee.common.utils.DateUtils;
|
||||
import com.fastbee.deviceData.domain.DeviceRealtimedataMeteorology;
|
||||
import com.fastbee.deviceData.mapper.DeviceRealtimedataMeteorologyMapper;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.stereotype.Service;
|
||||
|
||||
import java.math.BigDecimal;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
/**
|
||||
* devLink气象设备数据服务
|
||||
*/
|
||||
@Service
|
||||
public class DevLinkMetDataService {
|
||||
|
||||
@Autowired
|
||||
private DevLinkAuthorizationService authorizationService;
|
||||
|
||||
@Autowired
|
||||
private DeviceRealtimedataMeteorologyMapper deviceRealtimedataMeteorologyMapper;
|
||||
|
||||
/**
|
||||
* 获取气象设备实时数据
|
||||
* @param deviceId 设备id
|
||||
* @return 实时数据
|
||||
*/
|
||||
public boolean getMetDeviceRealData(String deviceId){
|
||||
DevLinkAuthorizationService authorization = new DevLinkAuthorizationService();
|
||||
//构建请求体
|
||||
HashMap<String, Object> body = new HashMap<>();
|
||||
body.put("method","get");
|
||||
body.put("path","api/v1/product/device/run_status");
|
||||
Map<String,Object> params=new HashMap<>();
|
||||
params.put("id",deviceId);
|
||||
body.put("params",params);
|
||||
String jsonStr = JSONUtil.toJsonStr(body);
|
||||
System.err.println(authorization.getBaseUrl() + authorization.getAuth());
|
||||
String result = HttpUtil.post(authorization.getBaseUrl() + authorization.getAuth(), jsonStr);
|
||||
// System.err.println(result);
|
||||
JSONObject jsonObject = JSONUtil.parseObj(result);
|
||||
Object data = jsonObject.get("data");
|
||||
//获取设备状态
|
||||
JSONObject jsonObjectData = JSONUtil.parseObj(data);
|
||||
Object status = jsonObjectData.get("status");
|
||||
// System.err.println("status:"+status);
|
||||
//获取设备属性以及实时数据值
|
||||
Object properties = jsonObjectData.get("properties");
|
||||
JSONArray propertiesArray = JSONUtil.parseArray(properties);
|
||||
DeviceRealtimedataMeteorology realData = new DeviceRealtimedataMeteorology();
|
||||
//获取设备各项属性实时数据
|
||||
propertiesArray.forEach(p -> {
|
||||
|
||||
Object property = JSONUtil.parseObj(p).get("property");
|
||||
JSONObject propertyMap = JSONUtil.parseObj(property);
|
||||
// System.err.println("propertyMap:"+propertyMap);
|
||||
//属性名称
|
||||
String name = propertyMap.get("name").toString();
|
||||
//属性key
|
||||
String key = propertyMap.get("key").toString();
|
||||
//属性值
|
||||
String value = JSONUtil.parseObj(p).get("value").toString();
|
||||
//TODO 属性值历史数据,是否需要
|
||||
Object list = JSONUtil.parseObj(p).get("list");
|
||||
|
||||
// System.err.print("name:"+name);
|
||||
System.err.print("key:"+key);
|
||||
System.err.println("------------value:"+value);
|
||||
|
||||
saveRealData(key,value,realData);
|
||||
|
||||
});
|
||||
System.err.println(realData);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
||||
//数据持久化
|
||||
public void saveRealData(String key, String value, DeviceRealtimedataMeteorology realData){
|
||||
|
||||
switch (key) {
|
||||
case "airTemp":
|
||||
realData.setAirTemp(BigDecimal.valueOf(Double.parseDouble(value)));
|
||||
break;
|
||||
case "airHumi":
|
||||
realData.setAirHumi(BigDecimal.valueOf(Double.parseDouble(value)));
|
||||
break;
|
||||
case "windSpeed":
|
||||
realData.setWindSpeed(BigDecimal.valueOf(Double.parseDouble(value)));
|
||||
break;
|
||||
case "windDir":
|
||||
realData.setWindDir(Long.parseLong(value));
|
||||
break;
|
||||
case "airPre":
|
||||
realData.setAirPre(BigDecimal.valueOf(Double.parseDouble(value)));
|
||||
break;
|
||||
case "guangzhao":
|
||||
realData.setGuangzhao(Long.parseLong(value));
|
||||
break;
|
||||
case "fushe":
|
||||
realData.setFushe(BigDecimal.valueOf(Double.parseDouble(value)));
|
||||
break;
|
||||
case "sumRain":
|
||||
realData.setSumRain(BigDecimal.valueOf(Double.parseDouble(value)));
|
||||
break;
|
||||
case "insRain":
|
||||
realData.setInsRain(BigDecimal.valueOf(Double.parseDouble(value)));
|
||||
break;
|
||||
case "dayRain":
|
||||
realData.setDayRain(BigDecimal.valueOf(Double.parseDouble(value)));
|
||||
break;
|
||||
case "zhengfa":
|
||||
realData.setZhengfa(BigDecimal.valueOf(Double.parseDouble(value)));
|
||||
break;
|
||||
case "soilTemp":
|
||||
realData.setSoilTemp(BigDecimal.valueOf(Double.parseDouble(value)));
|
||||
break;
|
||||
case "soilHumi":
|
||||
realData.setSoilHumi(BigDecimal.valueOf(Double.parseDouble(value)));
|
||||
break;
|
||||
}
|
||||
realData.setCreateTime(DateUtils.getNowDate());
|
||||
deviceRealtimedataMeteorologyMapper.insertDeviceRealtimedataMeteorology(realData);
|
||||
}
|
||||
|
||||
//获取属性值
|
||||
public String getPropertyValue(JSONObject map, String key){
|
||||
// System.err.println(map);
|
||||
String mapKey = map.get("key").toString();
|
||||
if(mapKey.equals(key)){
|
||||
return map.get("value").toString();
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
public static void main(String[] args) {
|
||||
DevLinkMetDataService service = new DevLinkMetDataService();
|
||||
service.getMetDeviceRealData("3269");
|
||||
// service.;
|
||||
}
|
||||
}
|
@ -1,73 +0,0 @@
|
||||
package com.fastbee.deviceData.api.devlink.service;
|
||||
|
||||
import cn.hutool.http.HttpUtil;
|
||||
import cn.hutool.json.JSONArray;
|
||||
import cn.hutool.json.JSONObject;
|
||||
import cn.hutool.json.JSONUtil;
|
||||
import com.fastbee.deviceData.mapper.DeviceRealtimedataPhotovoltaicMapper;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.stereotype.Service;
|
||||
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
@Service
|
||||
public class DevLinkMoistureService {
|
||||
|
||||
@Autowired
|
||||
private DevLinkAuthorizationService authorizationService;
|
||||
|
||||
@Autowired
|
||||
private DeviceRealtimedataPhotovoltaicMapper deviceRealtimedataPhotovoltaicMapper;
|
||||
|
||||
/**
|
||||
* 获取设备列表
|
||||
*/
|
||||
public List<?> getMoistureDevice(){
|
||||
DevLinkAuthorizationService authorization = new DevLinkAuthorizationService();
|
||||
//构建请求体
|
||||
HashMap<String, Object> body = new HashMap<>();
|
||||
body.put("method","get");
|
||||
body.put("path","api/v1/product/device/run_status");
|
||||
Map<String,Object> params=new HashMap<>();
|
||||
params.put("id","3269");
|
||||
body.put("params",params);
|
||||
String jsonStr = JSONUtil.toJsonStr(body);
|
||||
System.err.println(authorization.getBaseUrl() + authorization.getAuth());
|
||||
String result = HttpUtil.post(authorization.getBaseUrl() + authorization.getAuth(), jsonStr);
|
||||
System.err.println(result);
|
||||
JSONObject jsonObject = JSONUtil.parseObj(result);
|
||||
Object data = jsonObject.get("data");
|
||||
//获取设备状态
|
||||
JSONObject jsonObjectData = JSONUtil.parseObj(data);
|
||||
Object status = jsonObjectData.get("status");
|
||||
//获取设备属性以及实时数据值
|
||||
Object properties = jsonObject.get("properties");
|
||||
JSONArray propertiesArray = JSONUtil.parseArray(properties);
|
||||
//获取设备各项属性实时数据
|
||||
propertiesArray.forEach(p -> {
|
||||
|
||||
Object property = JSONUtil.parseObj(p).get("property");
|
||||
JSONObject propertyMap = JSONUtil.parseObj(property);
|
||||
//属性名称
|
||||
propertyMap.get("name");
|
||||
//属性key
|
||||
propertyMap.get("key");
|
||||
//属性值
|
||||
Object value = JSONUtil.parseObj(p).get("value");
|
||||
//TODO 属性值历史数据,是否需要
|
||||
Object list = JSONUtil.parseObj(p).get("list");
|
||||
//TODO 封装所需数据
|
||||
deviceRealtimedataPhotovoltaicMapper.insertDeviceRealtimedataPhotovoltaic(null);
|
||||
|
||||
});
|
||||
|
||||
return null;
|
||||
}
|
||||
|
||||
public static void main(String[] args) {
|
||||
DevLinkMoistureService service = new DevLinkMoistureService();
|
||||
service.getMoistureDevice();
|
||||
}
|
||||
}
|
@ -4,6 +4,7 @@ import java.math.BigDecimal;
|
||||
import io.swagger.annotations.ApiModel;
|
||||
import io.swagger.annotations.ApiModelProperty;
|
||||
import lombok.Data;
|
||||
import lombok.EqualsAndHashCode;
|
||||
import org.apache.commons.lang3.builder.ToStringBuilder;
|
||||
import org.apache.commons.lang3.builder.ToStringStyle;
|
||||
import com.fastbee.common.annotation.Excel;
|
||||
|
Loading…
x
Reference in New Issue
Block a user