From 72cf5cdaef3be1e81da7f59d6ed61fe368f44816 Mon Sep 17 00:00:00 2001
From: cloudroam <cloudroam>
Date: 星期三, 08 一月 2025 14:48:46 +0800
Subject: [PATCH] add:物流发货针对散户更改微信发货方式,保存物流单号,未发送之前可更改
---
src/main/java/com/mzl/flower/web/payment/OrderController.java | 7 +++++++
src/main/java/com/mzl/flower/service/payment/OrderService.java | 23 ++++++++++++++++-------
src/main/java/com/mzl/flower/dto/response/payment/OrderDTO.java | 3 +++
src/main/java/com/mzl/flower/service/payment/WxDeliveryGoodService.java | 15 +++++++++++++--
4 files changed, 39 insertions(+), 9 deletions(-)
diff --git a/src/main/java/com/mzl/flower/dto/response/payment/OrderDTO.java b/src/main/java/com/mzl/flower/dto/response/payment/OrderDTO.java
index b2a330e..9727003 100644
--- a/src/main/java/com/mzl/flower/dto/response/payment/OrderDTO.java
+++ b/src/main/java/com/mzl/flower/dto/response/payment/OrderDTO.java
@@ -172,4 +172,7 @@
@ApiModelProperty(value = " 使用条件(满多少钱)")
private String minOrderAmount;
+
+ @ApiModelProperty(value = "快递单号")
+ private String deliveryNo;
}
diff --git a/src/main/java/com/mzl/flower/service/payment/OrderService.java b/src/main/java/com/mzl/flower/service/payment/OrderService.java
index 2f92e46..7149095 100644
--- a/src/main/java/com/mzl/flower/service/payment/OrderService.java
+++ b/src/main/java/com/mzl/flower/service/payment/OrderService.java
@@ -817,6 +817,10 @@
throw new ValidationException("快递号不能为空");
}
Order o = orderMapper.selectById(dto.getId());
+ //上传快递号逻辑调整:由原来输入快递单号直接发送,调整先输入快递单号再点击发送,先保存订单得快递号
+ if (StringUtils.isEmpty(o.getDeliveryNo())) {
+ throw new ValidationException("快递号不能为空");
+ }
if (!Constants.ORDER_STATUS_BACKEND.SEND.name().equals(o.getStatusBackend())) {
throw new ValidationException("请先完成质检");
}
@@ -835,6 +839,17 @@
o.setWxDeliveryMsg(GsonUtil.toJson(jsonObject));
}
+ orderMapper.updateById(o);
+ }
+
+ public void saveDeliveryNoInfo(OrderDeliveryNoDTO dto) {
+ //上传快递号逻辑调整:由原来输入快递单号直接发送,调整先输入快递单号再点击发送,先保存订单得快递号
+ Order o = orderMapper.selectById(dto.getId());
+ if (!Constants.ORDER_STATUS_BACKEND.SEND.name().equals(o.getStatusBackend())) {
+ throw new ValidationException("请先完成质检");
+ }
+ o.setDeliveryNo(dto.getDeliveryNo());
+ o.update(SecurityUtils.getUserId());
orderMapper.updateById(o);
}
@@ -1274,13 +1289,7 @@
sb.append(item.getFlowerName() + "*" + item.getNum() + "扎、");//商品信息
}
try {
- json = wxDeliveryGoodService.wxDeliveryGood(
- o.getId(),
- o.getPayOpenid(),
- o.getPaymentTrId(),
- sb.toString(),
- PyamentV3Configurer.merchantId,
- accessToken);
+ json = wxDeliveryGoodService.wxDeliveryGood(o.getId(), o.getPayOpenid(), o.getPaymentTrId(), sb.toString(), PyamentV3Configurer.merchantId, accessToken, o.getPartnerId(), o.getDeliveryNo());
} catch (Exception e) {
log.error("订单" + o.getOrderNo() + "发货,调用微信发货接口失败", e);
json.put("errcode", -1);
diff --git a/src/main/java/com/mzl/flower/service/payment/WxDeliveryGoodService.java b/src/main/java/com/mzl/flower/service/payment/WxDeliveryGoodService.java
index bd48266..c915d58 100644
--- a/src/main/java/com/mzl/flower/service/payment/WxDeliveryGoodService.java
+++ b/src/main/java/com/mzl/flower/service/payment/WxDeliveryGoodService.java
@@ -8,6 +8,7 @@
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
+import org.springframework.util.StringUtils;
import java.time.ZonedDateTime;
import java.time.format.DateTimeFormatter;
@@ -19,7 +20,7 @@
public class WxDeliveryGoodService {
public JSONObject wxDeliveryGood(String orderId, String openid, String transactionId,
- String itemDesc, String merchantId,String accessToken) throws Exception {
+ String itemDesc, String merchantId,String accessToken, Long partnerID,String deliveryNo) throws Exception {
String requestPath = "https://api.weixin.qq.com/wxa/sec/order/upload_shipping_info?access_token="+accessToken;
Map<String, Object> headers = new HashMap<>();
headers.put("Accept", MediaType.APPLICATION_JSON.getValue());
@@ -31,13 +32,23 @@
orderKey.put("mchid",merchantId);//支付下单商户的商户号,由微信支付生成并下发。
orderKey.put("out_trade_no",orderId);//商户系统内部订单号
body.put("order_key",orderKey);
- body.put("logistics_type",2);//物流模式,发货方式枚举值:1、实体物流配送采用快递公司进行实体物流配送形式 2、同城配送 3、虚拟商品,虚拟商品,例如话费充值,点卡等,无实体配送形式 4、用户自提
body.put("delivery_mode",1);//发货模式,发货模式枚举值:1、UNIFIED_DELIVERY(统一发货)2、SPLIT_DELIVERY(分拆发货) 示例值: UNIFIED_DELIVERY
+ if (StringUtils.isEmpty(partnerID) && !StringUtils.isEmpty(deliveryNo)) {
+ // 如果是散户的情况下保存订单号
+ body.put("logistics_type", 1);//物流模式,发货方式枚举值:1、实体物流配送采用快递公司进行实体物流配送形式 2、同城配送 3、虚拟商品,虚拟商品,例如话费充值,点卡等,无实体配送形式 4、用户自提
+ } else {
+ body.put("logistics_type", 2);//物流模式,发货方式枚举值:1、实体物流配送采用快递公司进行实体物流配送形式 2、同城配送 3、虚拟商品,虚拟商品,例如话费充值,点卡等,无实体配送形式 4、用户自提
+ }
+
+
//商品信息
List<Map<String,Object>> shippingList = new ArrayList<>();
Map<String,Object> itemMap = new HashMap<>();
itemMap.put("item_desc",itemDesc);//商品描述
+ if (StringUtils.isEmpty(partnerID) && !StringUtils.isEmpty(deliveryNo)) {
+ itemMap.put("tracking_no", deliveryNo);//物流单号,物流快递发货时必填,示例值: 323244567777 字符字节限制: [1, 128]
+ }
shippingList.add(itemMap);
body.put("shipping_list",shippingList);
diff --git a/src/main/java/com/mzl/flower/web/payment/OrderController.java b/src/main/java/com/mzl/flower/web/payment/OrderController.java
index b82944f..8cf080b 100644
--- a/src/main/java/com/mzl/flower/web/payment/OrderController.java
+++ b/src/main/java/com/mzl/flower/web/payment/OrderController.java
@@ -84,6 +84,13 @@
return returnData(R.SUCCESS.getCode(), null);
}
+
+ @PostMapping("/list/saveDeliveryNo")
+ @ApiOperation(value = "没有合伙人的花店上传快递号保存但是不发货")
+ public ResponseEntity<ReturnDataDTO> saveDeliveryNoInfo(@RequestBody OrderDeliveryNoDTO dto) {
+ orderService.saveDeliveryNoInfo(dto);
+ return returnData(R.SUCCESS.getCode(), null);
+ }
@GetMapping("/list/abnormal/details")
@ApiOperation(value = "异常订单明细")
@ApiImplicitParams({
--
Gitblit v1.9.3