From 6f1997123fc1e30f5782e82ee8d2b6b2a11d5ceb Mon Sep 17 00:00:00 2001
From: lidongdong <1459917685@qq.com>
Date: 星期五, 17 三月 2023 11:22:48 +0800
Subject: [PATCH] 新增银联支付查询   退款查询   接口

---
 springcloud_k8s_panzhihuazhihuishequ/applets/src/main/java/com/panzhihua/applets/unionpay/RefundQuery.java |   31 ++++++++++++++++++++++++-------
 1 files changed, 24 insertions(+), 7 deletions(-)

diff --git a/springcloud_k8s_panzhihuazhihuishequ/applets/src/main/java/com/panzhihua/applets/unionpay/RefundQuery.java b/springcloud_k8s_panzhihuazhihuishequ/applets/src/main/java/com/panzhihua/applets/unionpay/RefundQuery.java
index aa14371..26888c1 100644
--- a/springcloud_k8s_panzhihuazhihuishequ/applets/src/main/java/com/panzhihua/applets/unionpay/RefundQuery.java
+++ b/springcloud_k8s_panzhihuazhihuishequ/applets/src/main/java/com/panzhihua/applets/unionpay/RefundQuery.java
@@ -1,5 +1,6 @@
 package com.panzhihua.applets.unionpay;
 
+import com.panzhihua.common.utlis.DateUtils;
 import org.apache.commons.codec.binary.Base64;
 import org.apache.commons.codec.digest.DigestUtils;
 
@@ -9,6 +10,7 @@
 import java.net.HttpURLConnection;
 import java.net.URL;
 import java.net.URLConnection;
+import java.time.LocalDateTime;
 
 /**
  * @author kkqiao
@@ -23,23 +25,38 @@
 
     static String url = "https://test-api-open.chinaums.com/v1/netpay/refund-query";
 
-    public static void main(String[] args) throws Exception{
+    /**
+     * 退款查询接口
+     * @param args
+     * @return
+     */
+    public static String refundQuery(String merOrderId)
+    {
         //1. 组建请求报文
+        LocalDateTime time= DateUtils.getCurrentDate();
         RefundQueryBody reqBody = new RefundQueryBody();
-        reqBody.requestTimestamp = "2019-08-09 14:45:55";
-        reqBody.mid = "898460107420248";
-        reqBody.tid = "00000001";
-        reqBody.instMid = "MINIDEFAULT";
-        reqBody.merOrderId = "101771300dc89764b477474";
+        reqBody.requestTimestamp =time.format(DateUtils.format_ymdhms);// "2019-08-09 14:45:55";
+        reqBody.mid = UnionpayContent.MID;
+        reqBody.tid = UnionpayContent.TID;
+        reqBody.instMid = UnionpayContent.INSTMID;
+        reqBody.merOrderId = merOrderId;
         System.out.println("request body:\n"+reqBody);
 
         //2. 获取认证报文,timestamp为当前日期,老旧日期无法请求成功
-        String authorization = getAuthorization(UnionpayContent.APPID,UnionpayContent.APPKEY,"20190809145000","nonce",reqBody.toString());
+        String authorization = null;
+        try {
+            authorization = getAuthorization(UnionpayContent.APPID,UnionpayContent.APPKEY,
+                    time.format(DateUtils.format_ymdhms_string),"nonce",reqBody.toString());
+        } catch (Exception e) {
+            e.printStackTrace();
+            return "退款查询失败";
+        }
         System.out.println("authorization:\n"+authorization);
 
         //3. 发送http请求,并解析返回信息
         String response = request(url,authorization,reqBody.toString());
         System.out.println("response:\n"+response);
+        return response;
     }
 
     /**

--
Gitblit v1.7.1