1. 联调

This commit is contained in:
邱贞招 2024-06-17 10:12:59 +08:00
parent 5822ff6d51
commit a15c7a369a
8 changed files with 70 additions and 24 deletions

View File

@ -1,17 +1,13 @@
package com.ruoyi.web.controller.app; package com.ruoyi.web.controller.app;
import cn.hutool.core.util.StrUtil; import cn.hutool.core.util.StrUtil;
import com.ruoyi.common.annotation.Log;
import com.ruoyi.common.core.controller.BaseController; import com.ruoyi.common.core.controller.BaseController;
import com.ruoyi.common.core.domain.AjaxResult; import com.ruoyi.common.core.domain.AjaxResult;
import com.ruoyi.common.core.page.TableDataInfo; import com.ruoyi.common.core.page.TableDataInfo;
import com.ruoyi.common.enums.BusinessType;
import com.ruoyi.common.utils.CommonUtil; import com.ruoyi.common.utils.CommonUtil;
import com.ruoyi.system.domain.*; import com.ruoyi.system.domain.*;
import com.ruoyi.system.service.*; import com.ruoyi.system.service.*;
import com.wechat.pay.java.service.payments.model.Transaction; import com.wechat.pay.java.service.payments.model.Transaction;
import com.wechat.pay.java.service.refund.RefundService;
import com.wechat.pay.java.service.refund.model.QueryByOutRefundNoRequest;
import com.wechat.pay.java.service.refund.model.Refund; import com.wechat.pay.java.service.refund.model.Refund;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*; import org.springframework.web.bind.annotation.*;

View File

@ -14,6 +14,7 @@ import com.ruoyi.common.core.page.TableDataInfo;
import com.ruoyi.common.enums.BusinessType; import com.ruoyi.common.enums.BusinessType;
import com.ruoyi.common.exception.ServiceException; import com.ruoyi.common.exception.ServiceException;
import com.ruoyi.common.utils.CommonUtil; import com.ruoyi.common.utils.CommonUtil;
import com.ruoyi.common.utils.DateUtils;
import com.ruoyi.common.utils.SecurityUtils; import com.ruoyi.common.utils.SecurityUtils;
import com.ruoyi.common.utils.verify.vo.IDResponse; import com.ruoyi.common.utils.verify.vo.IDResponse;
import com.ruoyi.framework.web.service.TokenService; import com.ruoyi.framework.web.service.TokenService;
@ -25,7 +26,6 @@ import com.ruoyi.system.service.*;
import com.wechat.pay.java.service.payments.jsapi.model.PrepayWithRequestPaymentResponse; import com.wechat.pay.java.service.payments.jsapi.model.PrepayWithRequestPaymentResponse;
import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.NotNull;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.security.access.prepost.PreAuthorize;
import org.springframework.transaction.annotation.Transactional; import org.springframework.transaction.annotation.Transactional;
import org.springframework.web.bind.annotation.*; import org.springframework.web.bind.annotation.*;
@ -721,4 +721,19 @@ public class AppVerifyController extends BaseController
return AjaxResult.success("操作成功",aBoolean); return AjaxResult.success("操作成功",aBoolean);
} }
/**
* sn和mac号绑定
*/
@PostMapping("/band")
public AjaxResult bandSn(String sn,String mac)
{
logger.info("sn和mac号绑定【sn="+sn+"【mac="+mac+"");
AsDevice asDevice = new AsDevice();
asDevice.setSn(sn);
asDevice.setMac(mac);
asDevice.setStatus(ServiceConstants.VEHICLE_STATUS_NOT_BAND);
asDevice.setCreateTime(DateUtils.getNowDate());
return toAjax(asDeviceService.bandSn(asDevice));
}
} }

View File

@ -119,6 +119,10 @@ public class ServiceConstants {
/**----------------------------车辆状态start----------------------------*/ /**----------------------------车辆状态start----------------------------*/
/** 车辆状态: 0 未上架1-正常2-预约中3-骑行中4-临时锁车8-下线9-废弃 */ /** 车辆状态: 0 未上架1-正常2-预约中3-骑行中4-临时锁车8-下线9-废弃 */
/**
* 车辆状态: 7 未绑定
*/
public static final String VEHICLE_STATUS_NOT_BAND = "7";
/** /**
* 车辆状态: 0 未上架 * 车辆状态: 0 未上架
*/ */

View File

@ -3,38 +3,45 @@ package com.ruoyi.common.utils.wx;
import cn.binarywang.wx.miniapp.api.WxMaService; import cn.binarywang.wx.miniapp.api.WxMaService;
import cn.binarywang.wx.miniapp.api.impl.WxMaServiceImpl; import cn.binarywang.wx.miniapp.api.impl.WxMaServiceImpl;
import cn.binarywang.wx.miniapp.config.impl.WxMaDefaultConfigImpl; import cn.binarywang.wx.miniapp.config.impl.WxMaDefaultConfigImpl;
import com.ruoyi.common.utils.spring.SpringUtils;
import lombok.SneakyThrows; import lombok.SneakyThrows;
import lombok.extern.slf4j.Slf4j;
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.TimeUnit; import java.util.concurrent.TimeUnit;
@Slf4j
public class AccessTokenUtil { public class AccessTokenUtil {
/** 缓存token */ // 存储每个租户的token和过期时间
private static String cachedToken; private static final ConcurrentHashMap<String, String> cachedTokens = new ConcurrentHashMap<>();
private static final ConcurrentHashMap<String, Long> tokenExpirationTimes = new ConcurrentHashMap<>();
/** token过期时间 */
private static long tokenExpirationTime;
@SneakyThrows @SneakyThrows
public static String getToken(String appid, String appsecret) { public static String getToken(String appid, String appsecret) {
if (isTokenExpired()) { String cacheKey = appid + ":" + appsecret;
if (isTokenExpired(cacheKey)) {
log.info("token已过期重新获取");
WxMaService wxMaService = new WxMaServiceImpl(); WxMaService wxMaService = new WxMaServiceImpl();
WxMaDefaultConfigImpl config = new WxMaDefaultConfigImpl(); WxMaDefaultConfigImpl config = new WxMaDefaultConfigImpl();
config.setAppid(appid); config.setAppid(appid);
config.setSecret(appsecret); config.setSecret(appsecret);
wxMaService.setWxMaConfig(config); wxMaService.setWxMaConfig(config);
String accessToken = wxMaService.getAccessToken(); String accessToken = wxMaService.getAccessToken();
cachedToken = accessToken;
// 更新 token 过期时间 // 更新缓存
tokenExpirationTime = System.currentTimeMillis() + TimeUnit.SECONDS.toMillis(3600L); cachedTokens.put(cacheKey, accessToken);
return cachedToken; tokenExpirationTimes.put(cacheKey, System.currentTimeMillis() + TimeUnit.SECONDS.toMillis(3600L));
return accessToken;
} }
return cachedToken; log.info("token未过期直接使用");
return cachedTokens.get(cacheKey);
} }
/**判断token是否过期*/ /**判断token是否过期*/
private static boolean isTokenExpired() { private static boolean isTokenExpired(String cacheKey) {
return cachedToken == null || System.currentTimeMillis() > tokenExpirationTime; Long expirationTime = tokenExpirationTimes.get(cacheKey);
return expirationTime == null || System.currentTimeMillis() > expirationTime;
} }
} }

View File

@ -49,6 +49,11 @@ public class AsDevice extends BaseEntityPlus implements Serializable {
@TableField(exist = false) @TableField(exist = false)
private String qrText; private String qrText;
/** 运营商 */
@Excel(name = "运营商")
@TableField(exist = false)
private String deptName;
/** 分区 */ /** 分区 */
@Excel(name = "分区id") @Excel(name = "分区id")
private Long areaId; private Long areaId;

View File

@ -256,6 +256,12 @@ public interface IAsDeviceService extends IService<AsDevice>
*/ */
boolean checkMACUnique(AsDevice asDevice); boolean checkMACUnique(AsDevice asDevice);
/**
* sn和mac号绑定
*/
int bandSn(AsDevice asDevice);
// /** // /**
// * 是否靠近运营区边界 // * 是否靠近运营区边界
// */ // */

View File

@ -239,9 +239,12 @@ public class AsDeviceServiceImpl extends ServiceImpl<AsDeviceMapper, AsDevice> i
String typeName = sysDictDataService.selectDictLabel("as_device_status", status); String typeName = sysDictDataService.selectDictLabel("as_device_status", status);
asDevice1.setStatusStr(typeName); asDevice1.setStatusStr(typeName);
} }
SysDept sysDept = wxPayService.getDeptObjByAreaId(areaId); if(ObjectUtil.isNotNull(areaId)){
asDevice1.setQrText(sysDept.getDomain()+"?sn="+asDevice1.getSn()); SysDept sysDept = wxPayService.getDeptObjByAreaId(areaId);
//https://dianche.chuantewulian.cn?sn=https://dche.ccttiot.com?sn=3000900 //https://dianche.chuantewulian.cn?sn=https://dche.ccttiot.com?sn=3000900
asDevice1.setQrText(sysDept.getDomain()+"?sn="+asDevice1.getSn());
asDevice1.setDeptName(sysDept.getDeptName());
}
} }
return asDevices; return asDevices;
} }
@ -1435,6 +1438,16 @@ public class AsDeviceServiceImpl extends ServiceImpl<AsDeviceMapper, AsDevice> i
} }
/**
* sn和mac号绑定
* 注册onenet设备
*/
@Override
public int bandSn(AsDevice asDevice) {
return asDeviceMapper.insert(asDevice);
}
/** /**
* 判断是否靠近边界 * 判断是否靠近边界
*/ */

View File

@ -63,8 +63,8 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
de.activation_time, de.online_status, de.create_by, de.create_time, de.update_by, de.activation_time, de.online_status, de.create_by, de.create_time, de.update_by,
de.update_time, de.last_time, de.remark, de.status, de.lock_status, de.location, de.update_time, de.last_time, de.remark, de.status, de.lock_status, de.location,
de.remaining_power, de.voltage, de.qrcode, de.longitude, de.latitude, de.is_area_out_outage, de.is_admin_unlocking from et_device de de.remaining_power, de.voltage, de.qrcode, de.longitude, de.latitude, de.is_area_out_outage, de.is_admin_unlocking from et_device de
inner join et_area_dept ad on ad.area_id = de.area_id left join et_area_dept ad on ad.area_id = de.area_id
inner join sys_dept d on d.dept_id = ad.dept_id left join sys_dept d on d.dept_id = ad.dept_id
where 1 = 1 where 1 = 1
<if test="deviceName != null and deviceName != ''"> and de.device_name like concat('%', #{deviceName}, '%')</if> <if test="deviceName != null and deviceName != ''"> and de.device_name like concat('%', #{deviceName}, '%')</if>
<if test="mac != null and mac != ''"> and de.mac = #{mac}</if> <if test="mac != null and mac != ''"> and de.mac = #{mac}</if>