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