From 951a71b7615103a33b5f0a1eaa4f94f2beb9fc18 Mon Sep 17 00:00:00 2001 From: cloudroam <cloudroam> Date: 星期五, 10 一月 2025 15:48:01 +0800 Subject: [PATCH] add:发货处理 --- src/main/java/com/mzl/flower/service/payment/WxDeliveryGoodService.java | 20 ++++++++++++++++++-- 1 files changed, 18 insertions(+), 2 deletions(-) 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 69f3cea..c5811ca 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,String logisticsCompanyCode, String maskedNumber) 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,28 @@ orderKey.put("mchid",merchantId);//支付下单商户的商户号,由微信支付生成并下发。 orderKey.put("out_trade_no",orderId);//商户系统内部订单号 body.put("order_key",orderKey); - body.put("logistics_type",4);//物流模式,发货方式枚举值: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] + itemMap.put("express_company", logisticsCompanyCode);//物流公司编码,快递公司ID,参见「查询物流公司编码列表」,物流快递发货时必填, 示例值: DHL 字符字节限制: [1, 128] + //联系方式,当发货的物流公司为顺丰时,联系方式为必填,收件人或寄件人联系方式二选一 + Map<String,Object> contact = new HashMap<>(); + contact.put("receiver_contact",maskedNumber);//收件人联系方式,收件人联系方式为,采用掩码传输,最后4位数字不能打掩码 示例值: `189****1234, 021-****1234, ****1234, 0**2-***1234, 0**2-******23-10, ****123-8008` 值限制: 0 ≤ value ≤ 1024 + itemMap.put("contact", contact); + } shippingList.add(itemMap); body.put("shipping_list",shippingList); -- Gitblit v1.9.3