首页 > 编程语言 >Java之微信支付(扫码支付模式二)案例实战-之支付完成后页面跳转方案

Java之微信支付(扫码支付模式二)案例实战-之支付完成后页面跳转方案

时间:2022-11-24 20:34:30浏览次数:42  
标签:map 扫码 String 支付 request 跳转 页面


摘要:做过微信扫码支付的同学都知道,微信扫码支付完成后,要跳转到指定的页面就比较麻烦了,这里我提供一种比较可行的方案,也许还有其他更多的方案,但是我这里分享下我们当时是怎么处理微信扫码支付完成后,跳转到指定页面的呢。

一:微信扫码支付流程:

       可以看前面写过的文章,具体地址:​​Java之微信支付(扫码支付模式二)案例实战​​ 

二:微信扫码支付完成后页面跳转流程:

2.1.支付订单页面:

Java之微信支付(扫码支付模式二)案例实战-之支付完成后页面跳转方案_微信扫码支付

2.2.返回微信支付二维码页面:

2.3.扫码支付步骤一:

Java之微信支付(扫码支付模式二)案例实战-之支付完成后页面跳转方案_扫码支付_02

2.4.扫码支付步骤二:

Java之微信支付(扫码支付模式二)案例实战-之支付完成后页面跳转方案_微信_03

2.5.扫码支付步骤三:

Java之微信支付(扫码支付模式二)案例实战-之支付完成后页面跳转方案_扫码支付_04

2.6.支付完成,跳转购买成功页面:

Java之微信支付(扫码支付模式二)案例实战-之支付完成后页面跳转方案_扫码支付_05

三:支付完成,跳转支付成功页面:

这里最关键的是就是调用微信的扫码支付接口后,接收到微信返回的二维码连接后,要同时输出一个页面,并且页面里面要写成一个模板,里面需要定时调用查询订单支付状态的接口,目前是每5s调用一次订单支付状态接口,发现支付状态返回成功,那么就跳转到页面里面配置的URL,也可以是动态URL,具体关键代码就是支付完成后,返回页面的代码,如下:

3.1.支付接口控制类:

@PostMapping("/create")
public String h5Pay(HttpServletRequest request,HttpServletResponse response,ModelMap maps){

String payType = request.getParameter("payType");
String productCode = request.getParameter("productCode");
Map<String, Object> map =new HashMap<String, Object>();
//参数校验
R checkParams = PayServiceHelper.checkParams(request);
if((Integer)checkParams.get("code")==500) {
maps.addAttribute("error",checkParams.get("msg"));
return "error";
}
//订单签名校验
boolean checkOrder = paymentInfoService.checkOrder(request);
if(!checkOrder) {
maps.addAttribute("error","验证签名失败");
return "error";
}

//request 参数封装Map
map = PayServiceHelper.getPayMap(request);
//订单校验是否存在,是否已支付
PaymentInfoEntity queryOrder = paymentInfoService.queryStatus((String)map.get("orderId"));
if(queryOrder!=null) {
maps.addAttribute("error","订单已支付");
return "error";
}
//增加交易记录
String order = paymentInfoService.insert(map);
map.put("order", order);
//发起支付
PayService payService = payServiceFactory.getPayService(payType, productCode);
// 微信扫码支付,需要传客户端IP地址
if (Constant.PayType.WXCODEPAY.getName().equals(payType) && Constant.ProductCode.PC.getName().equals(productCode)) {
String ipAddr = IPUtils.getIpAddr(request);
map.put("ipAddr", ipAddr);

String orderId = request.getParameter("orderId");
map.put("externalId", orderId);
map.put("url", url);
}
payService.h5Pay(map,request, response);

return "success";
}

3.2.支付接口实现类:

@Override
public void h5Pay(Map<String, Object> map, HttpServletResponse response) throws Exception {
BigDecimal bigDecimal = new BigDecimal(100);
String externalId = String.valueOf(map.get("externalId"));
String url = String.valueOf(map.get("url"));
String returnUrl = String.valueOf(map.get("returnUrl"));
String order = (String)map.get("order");
String ipAddr = (String) map.get("ipAddr");
PaymentInfoEntity paymentInfoEntity = paymentInfoService.queryOrder(map);
if(null == paymentInfoEntity) {
return;
}
// 订单实际支付金额
BigDecimal amount = paymentInfoEntity.getAmount();
WxPayUnifiedOrderRequest request = WxPayUnifiedOrderRequest.newBuilder()
.body("药品订单")
.totalFee(amount.multiply(bigDecimal).setScale(0,BigDecimal.ROUND_DOWN).intValue())
.outTradeNo(order)
.spbillCreateIp(ipAddr)
.notifyUrl(wechatAccountConfig.getNotifyUrl())
.tradeType(WxPayConstants.TradeType.NATIVE)
.productId("ydw")
.build();
//1. 统一下单
WxPayNativeOrderResult result = null;
try {
result = wxPayService.createOrder(request);
String codeUrl = result.getCodeUrl();
//增加网关支付请求记录
payGatewayService.insert(order, url);
//生成二维码的图片格式
int width = 300;
int height = 300;
Hashtable hints = new Hashtable();
// 内容所使用编码
hints.put(EncodeHintType.CHARACTER_SET, "utf-8");
BitMatrix bitMatrix = new MultiFormatWriter().encode(codeUrl, BarcodeFormat.QR_CODE, width, height, hints);
BufferedImage bufferedImage = QRUtil.toBufferedImage(bitMatrix);
byte[] data = imageToBytes(bufferedImage, "png");
BASE64Encoder encoder = new BASE64Encoder();
//转换成base64串
String png_base64 = encoder.encodeBuffer(data).trim();
//删除 \r\n
png_base64 = png_base64.replaceAll("\n", "").replaceAll("\r", "");
// 输出二维码的Base64编码到页面
response.setContentType("text/html;charset=" + "UTF-8");
response.getWriter().write(PayServiceHelper.builderWxCodeForm(url, externalId, "data:image/png;base64, " + png_base64));
response.getWriter().flush();
response.getWriter().close();
} catch (WxPayException e) {
e.printStackTrace();
} catch (WriterException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}

3.3.支付接口输出页面的工具类:

public static String builderWxCodeForm(String url, String orderId, String imgUrl) {
StringBuffer sBuffer= new StringBuffer();
sBuffer.append("<!DOCTYPE html>\n" +
"<html>\n" +
" <head> \n" +
" <meta charset=\"utf-8\">\n" +
" <meta http-equiv=\"X-UA-Compatible\" content=\"IE=edge\">\n" +
" <meta name=\"viewport\" content=\"width=750,user-scalable=no\">\n" +
" <link rel=\"icon\" href=\"static/ydw.ico\">\n" +
" <title>药兜网</title>\n" +
" <script>\n" +
" var lock=window.setInterval(function(){\n" +
" var ajax = new XMLHttpRequest();\n" +
" ajax.open('get','query?orderId='+"+orderId+");\n" +
" ajax.send();\n" +
" ajax.onreadystatechange = function () {\n" +
" console.log(ajax.status);\n" +
" if (ajax.status==200) {\n" +
"     var resText = ajax.responseText;\n" +
"     var data = eval('(' + resText + ')');\n" +
" if (data['status']==1) {\n" +
" window.location.href = \""+url+"/purchaseSuccess?orderId="+orderId+"\"\n" +
" window.clearInterval(lock);\n" +
"    }\n" +
"   }\n" +
" }\n" +
" },2000)\n" +
" \n" +
" </script>\n" +
" <style>\n" +
" #app {\n" +
" width: 100%;\n" +
" height: 100%;\n" +
" position: fixed;\n" +
" top: 0;\n" +
" left: 0;\n" +
" display: flex;\n" +
" flex-direction: row;\n" +
" justify-content: center;\n" +
" align-items: center;\n" +
" }\n" +
" #app .img {\n" +
" vertical-align: middle;\n" +
" }\n" +
"\n" +
" </style>\n" +
"\n" +
" </head>\n" +
" <body style=\"width:750px;margin:0 auto;background: black;\">\n" +
" <div id=\"app\" >\n" +
" <img src=\""+imgUrl+"\"/>\n" +
" </div>\n" +
" </body>\n" +
"</html>");
return sBuffer.toString();
}

最关键是就是最后一个方法,这里就是输出一个页面,里面有个定时器定时调用订单支付状态接口,如果返回支付成功,那么就跳转的购买成功页面,以上就是关于微信扫码支付完成后,跳转购买成功页面的解决方案,欢迎大家一起讨论,如果大家有更好的方案,欢迎留言,谢谢!

如有问题可以加群讨论解决:QQ群好:278298761

标签:map,扫码,String,支付,request,跳转,页面
From: https://blog.51cto.com/u_4679008/5884776

相关文章

  • 案例3_自动跳转首页和DOM_概述
    案例3_自动跳转首页:分析:1.显示页面效果<p>2.倒计时读秒效果实现2.1定义一个方法,获取span标签,修改span标签体内容,时间--2.2定义一个定时器,1秒执行一次该方法3.在方法......
  • 如何通过短链接跳转到小程序,或者跳转至小程序webview一个h5页面
    theme:channing-cyan一、需求背景:公司需要通过发送短信携带短链接,用户点击短链接跳转到小程序的某个页面,然后打开小程序该页面webviewh5页面,然后链接携带参数。使用技......
  • Android原生跳转到Flutter页面
    1.启动Flutter页面默认界面startActivity(FlutterActivity.withNewEngine().build(activity!!)) 2.启动Flutter指定的界面比如设置......
  • Java之支付宝(电脑网站支付)成功后 同步回调,异步回调验证签名报错解决思路
    摘要:在做支付宝电脑网站支付的接口时候(这里仅限使用支付宝官网提供的SDK接入支付宝支付接口),支付成功了,但是支付宝回调的时候老是报签名失败,经过查看资料,发现是支付宝公钥......
  • 支付系统场景设计-支付状态处理
    本文以 微信支付官方文档->微信Native支付->开发指引 如下文本开篇(点击访问原文链接)。用户支付成功后,商户可通过以下两种方式获取订单状态方法一:支付结果通知。用户支......
  • 解密某支付的JS加密代码
    直接上加密代码asyncfunctionsendReq(_0x2d4d49,_0x178049,_0x4abd97=null,_0x4a5641=null){const_0x427aa8=_0x19ce3a;try{var_0x179b4c;......
  • Taro 支付宝小程序Page页获取小程序启动时的参数
     支付宝扫码直接跳转到小程序指定的页面时,支付宝将其二维码链接转成小程序的启动参数query来传递。此时在Taro中Page页面获取这些参数支付宝如何获取各种场景的启动参数......
  • 配置案例|RS232转Profinet网关接包装扫码器
    本文主要介绍小疆智控(北京)技术有限公司生产的RS232转Profinet网关(产品型号:GW-PN5002)在计扫外包装中条码扫描方面的使用方法。案例说明:小疆智控生产的RS232转Profinet网......
  • golang 微信支付计算签名
    原文:1、签名算法(签名校验工具)签名生成的通用步骤如下:第一步,设所有发送或者接收到的数据为集合M,将集合M内非空参数值的参数按照参数名ASCII码从小到大排序(字典序),使用URL键......
  • 【luffy】支付宝支付
    目录1.支付宝支付介绍1.1了解1.2使用支付宝支付1.支付宝支付介绍1.1了解1.项目中需要有在线支付功能支付宝支付微信支付:需要备案域名云闪付2.以支......