From 9d55a1416f87fa513ed828fc559c8bbde3be2d8c Mon Sep 17 00:00:00 2001
From: lidongdong <1459917685@qq.com>
Date: 星期四, 16 十一月 2023 14:28:45 +0800
Subject: [PATCH] 修改微心愿列表我认领的接口
---
springcloud_k8s_panzhihuazhihuishequ/applets/src/main/java/com/panzhihua/applets/api/WxCallbackApi.java | 177 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++--
1 files changed, 171 insertions(+), 6 deletions(-)
diff --git a/springcloud_k8s_panzhihuazhihuishequ/applets/src/main/java/com/panzhihua/applets/api/WxCallbackApi.java b/springcloud_k8s_panzhihuazhihuishequ/applets/src/main/java/com/panzhihua/applets/api/WxCallbackApi.java
index abf7c9d..f83f4e9 100644
--- a/springcloud_k8s_panzhihuazhihuishequ/applets/src/main/java/com/panzhihua/applets/api/WxCallbackApi.java
+++ b/springcloud_k8s_panzhihuazhihuishequ/applets/src/main/java/com/panzhihua/applets/api/WxCallbackApi.java
@@ -12,6 +12,10 @@
import com.panzhihua.applets.umf.MyAESUtil;
import com.panzhihua.applets.umf.UmfPayUtil;
+import com.panzhihua.applets.unionpay.Query;
+import com.panzhihua.applets.unionpay.QueryEntiy;
+import com.panzhihua.applets.unionpay.Refund;
+import com.panzhihua.common.model.dtos.wx.UnionpayCarWash;
import com.panzhihua.common.model.vos.R;
import com.panzhihua.common.service.user.UserService;
import com.panzhihua.common.utlis.DateUtils;
@@ -60,7 +64,7 @@
@PostMapping("wxNotify")
public void payCallback(HttpServletRequest request, HttpServletResponse response) {
- log.info("微信支付回调start");
+ log.error("微信支付回调start");
String inputLine = "";
String notityXml = "";
try {
@@ -69,7 +73,7 @@
}
// 关闭流
request.getReader().close();
- log.info("微信回调内容信息:" + notityXml);
+ log.error("微信回调内容信息:" + notityXml);
// 解析成Json
org.json.JSONObject xmlJson = XML.toJSONObject(notityXml);
if (StringUtils.isNotEmpty(xmlJson.toString())) {
@@ -126,11 +130,12 @@
e.printStackTrace();
}
}
+
@GetMapping("wxNotifyAll")
public void payCallbackAll(HttpServletRequest request, HttpServletResponse response) {
//获取联动发送请求的参数
String requestParam = request.getQueryString();
- System.out.println("请求参数 :" + requestParam);
+ System.out.println("花城洗车请求参数 :" + requestParam);
//调用异步通知解析方法
UmfService service = new UmfServiceImpl("53461",file);
Map respMap = null;
@@ -143,7 +148,9 @@
//调用uu洗车支付成功回调
Map map=new HashMap();
map.put("orderId",respMap.get("order_id"));
- HttpClientUtil.sendPostByJson("https://api.uucsh.cn/notify/wx/pzh-pay",JSONObject.toJSONString(map),1,"appid","10000");;
+ HttpClientUtil.sendPostByJson("https://uu-api.imashuo.com/notify/wx/pzh-pay",JSONObject.toJSONString(map),
+ 1,"appid","10000");
+ log.error("花城洗车回调成功 :" + respMap.get("order_id"));
}
//调用SDK生成返回联动平台字符串,加到CONTENT中
String resMetaData = service.responseUMFMap(respMap);
@@ -163,14 +170,86 @@
out.flush();
out.close();
}
+
+
+ /**
+ * 银联支付回调专用 银联方面只能是有个post
+ * @param response
+ */
+ @PostMapping("wxNotifyAllUnionpay")
+ public void payCallbackAllUnionpay(@RequestParam("merOrderId") String merOrderId, HttpServletResponse response)
+ {
+ //获取联动发送请求的参数
+ log.error("花城洗车请求参数 :" + merOrderId);
+ log.error("花城洗车请求参数response :" + response.toString());
+ //调用异步通知解析方法
+ String content=Query.query(merOrderId);
+ QueryEntiy queryEntiy=JSONObject.parseObject(content,QueryEntiy.class);
+ log.error("花城洗车请求参数queryEntiy :" + queryEntiy.toString());
+ if(queryEntiy.getErrCode().equals("SUCCESS"))
+ {
+ //查询银联单号对应的洗车单号
+ R r=communityService.carWashById(merOrderId);
+ if(r.getCode()==200)
+ {
+
+ HashMap unionpayCarWash= (HashMap) r.getData();
+ //调用uu洗车支付成功回调
+ Map map=new HashMap();
+ map.put("orderId",unionpayCarWash.get("carWashId"));
+ HttpClientUtil.sendPostByJson("https://uu-api.imashuo.com/notify/wx/pzh-pay",JSONObject.toJSONString(map),
+ 1,"appid","10000");
+ log.error("花城洗车回调成功 :" + queryEntiy.getMerOrderId()+" : 洗车号"
+ +unionpayCarWash.get("carWashId")+" : 银联号"+unionpayCarWash.get("unionpayOrderId"));
+ }
+
+ }
+ //调用SDK生成返回联动平台字符串,加到CONTENT中
+ response.setContentType("text/html;charset=utf-8");
+ PrintWriter out = null;
+ try {
+ out = response.getWriter();
+ } catch (IOException e) {
+ e.printStackTrace();
+ }
+ out.println("<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.01 Transitional//EN\">");
+ out.println("<HTML>");
+ out.println("<HEAD><META NAME=\"MobilePayPlatform\" CONTENT=\"" + content + "\" /></HEAD>");
+ out.println("<BODY>");
+ out.println("</BODY>");
+ out.println("</HTML>");
+ out.flush();
+ out.close();
+ }
+
+
@ApiOperation("uu洗车退款接口")
@PostMapping("/uuRepay")
- public R uuRepay(@RequestBody String aesString){
+ public R uuRepay(@RequestBody String aesString)
+ {
try {
Map<String, String> aesMap= (Map<String, String>) JSON.parse(aesString);
String desString=MyAESUtil.Decrypt(aesMap.get("aesString"),"Ryo7M3n8loC5Abcd");
Map<String,String> desMap= (Map) JSON.parse(desString);
- Map map=umfPayUtil.repay(desMap.get("orderId"),desMap.get("merdate"), DateUtils.getDateFormatString(new Date(),"yyMMddHHmmss")+"0001",desMap.get("refundAmount"),desMap.get("orgAmount"));
+ Map map=umfPayUtil.repay(desMap.get("orderId"),desMap.get("merdate"), DateUtils.getDateFormatString(new Date(),
+ "yyMMddHHmmss")+"0001",desMap.get("refundAmount"),desMap.get("orgAmount"));
+
+ if(desMap.get("orderId")!=null)
+ {
+ R r=communityService.queryById(desMap.get("orderId"));
+ if(r.getCode()==200)
+ {
+ HashMap wash= (HashMap) r.getData();
+ if(wash!=null)
+ {
+ String re=Refund.sendOrder(wash.get("money").toString(),
+ wash.get("unionpayOrderId").toString());
+ map.put("unionpay","退款成功");
+ log.error("花城洗车银联退款成功 :" + re);
+ }
+
+ }
+ }
return R.ok(map);
} catch (Exception e) {
e.printStackTrace();
@@ -186,6 +265,21 @@
String desString=MyAESUtil.Decrypt(aesMap.get("aesString"),"Ryo7M3n8loC5Abcd");
Map<String,String> desMap= (Map) JSON.parse(desString);
return userService.uuPush(desMap.get("washer_mobile"),desMap.get("phone"),desMap.get("washer_name"),Integer.parseInt(desMap.get("order_status")));
+
+ } catch (Exception e) {
+ e.printStackTrace();
+ return R.fail("推送失败");
+ }
+
+ }
+ @ApiOperation("ws洗车推送")
+ @PostMapping("/wsPush")
+ public R wsPush(@RequestBody String aesString){
+ try {
+ Map<String, String> aesMap= (Map<String, String>) JSON.parse(aesString);
+ String desString=MyAESUtil.Decrypt(aesMap.get("aesString"),"Ryo7M3n8loC5Abcd");
+ Map<String,String> desMap= (Map) JSON.parse(desString);
+ return userService.wsPush(desMap.get("washer_mobile"),desMap.get("phone"),desMap.get("washer_name"),Integer.parseInt(desMap.get("order_status")));
} catch (Exception e) {
e.printStackTrace();
return R.fail("推送失败");
@@ -333,4 +427,75 @@
public R settle(String settleDate){
return R.ok(umfPayUtil.settle(settleDate));
}
+
+
+ @PostMapping("/flower/wxNotify")
+ @ApiOperation("花城支付回调")
+ public void flowerWxNotify(HttpServletRequest request, HttpServletResponse response) {
+ log.error("微信支付回调start");
+ String inputLine = "";
+ String notityXml = "";
+ try {
+ while ((inputLine = request.getReader().readLine()) != null) {
+ notityXml += inputLine;
+ }
+ // 关闭流
+ request.getReader().close();
+ log.error("微信回调内容信息:" + notityXml);
+ // 解析成Json
+ org.json.JSONObject xmlJson = XML.toJSONObject(notityXml);
+ if (StringUtils.isNotEmpty(xmlJson.toString())) {
+ JSONObject resultData = JSON.parseObject(xmlJson.get("xml").toString());
+ // 成功支付订单
+ if (resultData.getString("result_code").equals("SUCCESS")
+ && resultData.getString("return_code").equals("SUCCESS")) {
+ WxPayNotifyOrderDTO notifyOrderDTO = new WxPayNotifyOrderDTO();
+ // 订单号
+ String orderTradeNo = resultData.getString("out_trade_no");
+ notifyOrderDTO.setOrderTradeNo(orderTradeNo);
+ // 微信支付订单号
+ String wxTradeNo = resultData.getString("transaction_id");
+ notifyOrderDTO.setWxTradeNo(wxTradeNo);
+ // 订单金额
+ String totalFee = resultData.getString("total_fee");
+ notifyOrderDTO.setTotalFee(totalFee);
+ // 支付完成时间
+ String payTime = resultData.getString("time_end");
+ notifyOrderDTO.setPayTime(payTime);
+ // 现金支付金额
+ String cashFee = resultData.getString("cash_fee");
+ notifyOrderDTO.setCashFee(cashFee);
+
+ // 根据订单号修改订单信息
+ communityService.wxOrderPayNotifyFlower(notifyOrderDTO);
+
+ // 封装 返回值
+ StringBuffer buffer = new StringBuffer();
+ buffer.append("<xml>");
+ buffer.append("<return_code>SUCCESS</return_code>");
+ buffer.append("<return_msg>OK</return_msg>");
+ buffer.append("</xml>");
+
+ // 给微信服务器返回 成功标示 否则会一直询问 咱们服务器 是否回调成功
+ PrintWriter writer = response.getWriter();
+ // 返回
+ writer.print(buffer.toString());
+ } else {// 未成功支付订单
+ // 封装 返回值
+ StringBuffer buffer = new StringBuffer();
+ buffer.append("<xml>");
+ buffer.append("<return_code>FAIL</return_code>");
+ buffer.append("<return_msg>FAIL</return_msg>");
+ buffer.append("</xml>");
+
+ // 给微信服务器返回 成功标示 否则会一直询问 咱们服务器 是否回调成功
+ PrintWriter writer = response.getWriter();
+ // 返回
+ writer.print(buffer.toString());
+ }
+ }
+ } catch (IOException e) {
+ e.printStackTrace();
+ }
+ }
}
--
Gitblit v1.7.1