首页 > 其他分享 >SpringBoot 集成微信支付的各种支付产品

SpringBoot 集成微信支付的各种支付产品

时间:2023-03-31 16:04:35浏览次数:60  
标签:SpringBoot String 微信 wxPayService private 支付 orderRequest

Spring Boot 是一款非常流行的 Java 开发框架,而微信支付则是众多移动支付产品中的佼佼者,整合两者可以让我们更方便地开发各种支付产品。在本篇博客中,我将介绍如何在 Spring Boot 中整合微信支付的各种支付产品。

SpringBoot 集成微信支付的各种支付产品_微信支付

准备工作

微信支付官网

  • 注册一个微信支付商户账号
  • 创建一个微信支付应用程序并获取应用程序的AppID和AppSecret
  • 获取商户号和API密钥

首先,我们需要在 pom.xml 中添加以下依赖:

<dependency>
    <groupId>com.github.binarywang</groupId>
    <artifactId>weixin-java-pay</artifactId>
    <version>4.1.0</version>
</dependency>

然后,我们需要在 application.yml 中配置微信支付的相关信息:

wx:
  pay:
    app-id: your_app_id
    mch-id: your_mch_id
    mch-key: your_mch_key
    key-path: your_key_path
    notify-url: your_notify_url

接下来,我们就可以开始整合微信支付的各种支付产品了。

微信公众号支付

微信公众号支付是指在微信公众号内进行支付。在 Spring Boot 中整合微信公众号支付,我们需要使用 WxPayService 对象来进行支付。

首先,我们需要在配置类中注入 WxPayService 对象:

@Configuration
public class WxPayConfig {

    @Value("${wx.pay.app-id}")
    private String appId;

    @Value("${wx.pay.mch-id}")
    private String mchId;

    @Value("${wx.pay.mch-key}")
    private String mchKey;

    @Value("${wx.pay.key-path}")
    private String keyPath;

    @Value("${wx.pay.notify-url}")
    private String notifyUrl;

    @Bean
    public WxPayService wxPayService() throws Exception {
        WxPayConfig wxPayConfig = new WxPayConfig();
        wxPayConfig.setAppId(appId);
        wxPayConfig.setMchId(mchId);
        wxPayConfig.setMchKey(mchKey);
        wxPayConfig.setKeyPath(keyPath);

        WxPayService wxPayService = new WxPayServiceImpl();
        wxPayService.setConfig(wxPayConfig);
        wxPayService.setPayConfig(wxPayConfig);
        // 注册异步通知处理器
        wxPayService.setNotifyUrl(notifyUrl, "/notify");
        return wxPayService;
    }
}

然后,我们就可以在支付控制器中使用 WxPayService 对象来进行支付了:

@RestController
public class PayController {

    @Autowired
    private WxPayService wxPayService;

    @GetMapping("/pay")
    public String pay(HttpServletRequest request) throws Exception {
        // 构造订单信息
        WxPayUnifiedOrderRequest orderRequest = new WxPayUnifiedOrderRequest();
        orderRequest.setBody("订单描述");
        orderRequest.setOutTradeNo("订单号");
        orderRequest.setTotalFee(1);
        orderRequest.setSpbillCreateIp(request.getRemoteAddr());
        orderRequest.setNotifyUrl(notifyUrl);
        orderRequest.setTradeType(WxPayConstants.TradeType.JSAPI);
        orderRequest.setOpenid("用户的openid");

        // 调用统一下单接口
        WxPayMpOrderResult orderResult = wxPayService.createOrder(orderRequest);

        // 构造支付参数
        Map<String, String> payParams = new HashMap<>();
        payParams.put("appId", orderResult.getAppId());
		payParams.put("timeStamp", String.valueOf(System.currentTimeMillis() / 1000));
		payParams.put("nonceStr", orderResult.getNonceStr());
		payParams.put("package", "prepay_id=" + orderResult.getPrepayId());
		payParams.put("signType", "MD5");
		payParams.put("paySign", WXPayUtil.generateSignature(payParams, mchKey));

		return JSON.toJSONString(payParams);
	}
	
  	@PostMapping("/notify")
    public String notify(@RequestBody String xmlData) throws Exception {
        WxPayOrderNotifyResult notifyResult = wxPayService.parseOrderNotifyResult(xmlData);
        if (!WxPayConstants.ResultCode.SUCCESS.equals(notifyResult.getResultCode())) {
            // 支付失败,处理失败逻辑
            return WxPayNotifyResponse.fail("支付失败");
        }
        // 支付成功,处理成功逻辑
        String orderId = notifyResult.getOutTradeNo();
        // 更新订单状态等业务逻辑
        return WxPayNotifyResponse.success("OK");
    }
}

在这里,我们使用了 WxPayService.parseOrderNotifyResult() 方法将微信支付异步通知的 XML 数据解析为 WxPayOrderNotifyResult 对象。如果支付成功,则处理成功逻辑,否则处理失败逻辑。

最后,我们需要编写一个 WxPayNotifyResponse 类来封装异步通知的响应信息:

public class WxPayNotifyResponse {

    private static final String SUCCESS = "<xml><return_code><![CDATA[SUCCESS]]></return_code><return_msg><![CDATA[OK]]></return_msg></xml>";
    private static final String FAIL = "<xml><return_code><![CDATA[FAIL]]></return_code><return_msg><![CDATA[%s]]></return_msg></xml>";

    public static String success(String msg) {
        return SUCCESS;
    }

    public static String fail(String msg) {
        return String.format(FAIL, msg);
    }
}

微信扫码支付

微信扫码支付是指用户使用微信扫描商家的二维码进行支付。在 Spring Boot 中整合微信扫码支付,我们需要使用 WxPayService 对象来进行支付。

首先,我们需要在配置类中注入 WxPayService 对象;配置信息同公众号支付一样:

@Configuration
public class WxPayConfig {

    @Value("${wx.pay.app-id}")
    private String appId;

    @Value("${wx.pay.mch-id}")
    private String mchId;

    @Value("${wx.pay.mch-key}")
    private String mchKey;

    @Value("${wx.pay.key-path}")
    private String keyPath;

    @Value("${wx.pay.notify-url}")
    private String notifyUrl;

    @Bean
    public WxPayService wxPayService() throws Exception {
        WxPayConfig wxPayConfig = new WxPayConfig();
        wxPayConfig.setAppId(appId);
        wxPayConfig.setMchId(mchId);
        wxPayConfig.setMchKey(mchKey);
        wxPayConfig.setKeyPath(keyPath);

        WxPayService wxPayService = new WxPayServiceImpl();
        wxPayService.setConfig(wxPayConfig);
        wxPayService.setPayConfig(wxPayConfig);
        // 注册异步通知处理器
        wxPayService.setNotifyUrl(notifyUrl, "/notify");
        return wxPayService;
    }
}

然后,我们就可以在支付控制器中使用 WxPayService 对象来进行支付了:

@RestController
public class PayController {

    @Autowired
    private WxPayService wxPayService;

    @GetMapping("/pay")
    public String pay(HttpServletRequest request) throws Exception {
        // 构造订单信息
        WxPayUnifiedOrderRequest orderRequest = new WxPayUnifiedOrderRequest();
        orderRequest.setBody("订单描述");
        orderRequest.setOutTradeNo("订单号");
        orderRequest.setTotalFee(1);
        orderRequest.setSpbillCreateIp(request.getRemoteAddr());
        orderRequest.setNotifyUrl(notifyUrl);
        orderRequest.setTradeType(WxPayConstants.TradeType.NATIVE);
        orderRequest.setProductId("商品id");

        // 调用统一下单接口
        WxPayNativeOrderResult orderResult = wxPayService.createOrder(orderRequest);

        // 获取二维码链接
        String codeUrl = orderResult.getCodeUrl();

        return codeUrl;
    }
	
  	@PostMapping("/notify")
    public String notify(@RequestBody String xmlData) throws Exception {
        WxPayOrderNotifyResult notifyResult = wxPayService.parseOrderNotifyResult(xmlData);
        if (!WxPayConstants.ResultCode.SUCCESS.equals(notifyResult.getResultCode())) {
            // 支付失败,处理失败逻辑
            return WxPayNotifyResponse.fail("支付失败");
        }
        // 支付成功,处理成功逻辑
        String orderId = notifyResult.getOutTradeNo();
        // 更新订单状态等业务逻辑
        return WxPayNotifyResponse.success("OK");
    }
}

在这里,我们将 tradeType 参数设置为 WxPayConstants.TradeType.NATIVE,表示使用扫码支付方式。我们通过调用 createOrder() 方法生成订单,并从返回结果中获取二维码链接,然后使用 QrCodeUtil.createQrCode() 方法生成二维码图片。

注意,生成的二维码链接有效期为2小时,超时后需要重新生成。

我们使用了 WxPayService.parseOrderNotifyResult() 方法将微信支付异步通知的 XML 数据解析为 WxPayOrderNotifyResult 对象。如果支付成功,则处理成功逻辑,否则处理失败逻辑。

最后,我们需要编写一个 WxPayNotifyResponse 类来封装异步通知的响应信息:

public class WxPayNotifyResponse {

    private static final String SUCCESS = "<xml><return_code><![CDATA[SUCCESS]]></return_code><return_msg><![CDATA[OK]]></return_msg></xml>";
    private static final String FAIL = "<xml><return_code><![CDATA[FAIL]]></return_code><return_msg><![CDATA[%s]]></return_msg></xml>";

    public static String success(String msg) {
        return SUCCESS;
    }

    public static String fail(String msg) {
        return String.format(FAIL, msg);
    }
}

微信APP支付

微信APP支付是指在微信内部或者第三方应用中进行支付。在 Spring Boot 中整合微信APP支付,我们需要使用 WxPayService 对象来进行支付。

首先,我们需要在配置类中注入 WxPayService 对象:

@Configuration
public class WxPayConfig {

    @Value("${wx.pay.app-id}")
    private String appId;

    @Value("${wx.pay.mch-id}")
    private String mchId;

    @Value("${wx.pay.mch-key}")
    private String mchKey;

    @Value("${wx.pay.key-path}")
    private String keyPath;
    
	@Value("${wx.pay.notify-url}")
	private String notifyUrl;
	
	@Bean
	public WxPayService wxPayService() throws Exception {
	    WxPayConfig wxPayConfig = new WxPayConfig();
	    wxPayConfig.setAppId(appId);
	    wxPayConfig.setMchId(mchId);
	    wxPayConfig.setMchKey(mchKey);
	    wxPayConfig.setKeyPath(keyPath);
	
	    WxPayService wxPayService = new WxPayServiceImpl();
	    wxPayService.setConfig(wxPayConfig);
	    wxPayService.setPayConfig(wxPayConfig);
        // 注册异步通知处理器
        wxPayService.setNotifyUrl(notifyUrl, "/notify");	
	    return wxPayService;
	}
}

然后,我们就可以在支付控制器中使用 WxPayService 对象来进行支付了:

@RestController
public class PayController {

    @Autowired
    private WxPayService wxPayService;

    @PostMapping("/pay")
    public String pay(@RequestBody PayRequest payRequest) throws Exception {
        // 构造订单信息
        WxPayUnifiedOrderRequest orderRequest = new WxPayUnifiedOrderRequest();
        orderRequest.setBody(payRequest.getSubject());
        orderRequest.setOutTradeNo(payRequest.getOrderId());
        orderRequest.setTotalFee(payRequest.getAmount().intValue());
        orderRequest.setSpbillCreateIp(payRequest.getClientIp());
        orderRequest.setNotifyUrl(notifyUrl);
        orderRequest.setTradeType(WxPayConstants.TradeType.APP);

        // 调用统一下单接口
        WxPayAppOrderResult orderResult = wxPayService.createOrder(orderRequest);

        // 构造APP支付参数
        Map<String, String> payParams = new HashMap<>();
        payParams.put("appid", orderResult.getAppId());
        payParams.put("partnerid", orderResult.getPartnerId());
        payParams.put("prepayid", orderResult.getPrepayId());
        payParams.put("package", "Sign=WXPay");
        payParams.put("noncestr", orderResult.getNonceStr());
        payParams.put("timestamp", String.valueOf(System.currentTimeMillis() / 1000));
        payParams.put("sign", WXPayUtil.generateSignature(payParams, mchKey));

        return JSON.toJSONString(payParams);
    }
    	
  	@PostMapping("/notify")
    public String notify(@RequestBody String xmlData) throws Exception {
        WxPayOrderNotifyResult notifyResult = wxPayService.parseOrderNotifyResult(xmlData);
        if (!WxPayConstants.ResultCode.SUCCESS.equals(notifyResult.getResultCode())) {
            // 支付失败,处理失败逻辑
            return WxPayNotifyResponse.fail("支付失败");
        }
        // 支付成功,处理成功逻辑
        String orderId = notifyResult.getOutTradeNo();
        // 更新订单状态等业务逻辑
        return WxPayNotifyResponse.success("OK");
    }
}

在这里,我们使用了 WxPayService.parseOrderNotifyResult() 方法将微信支付异步通知的 XML 数据解析为 WxPayOrderNotifyResult 对象。如果支付成功,则处理成功逻辑,否则处理失败逻辑。

最后,我们需要编写一个 WxPayNotifyResponse 类来封装异步通知的响应信息:

public class WxPayNotifyResponse {

    private static final String SUCCESS = "<xml><return_code><![CDATA[SUCCESS]]></return_code><return_msg><![CDATA[OK]]></return_msg></xml>";
    private static final String FAIL = "<xml><return_code><![CDATA[FAIL]]></return_code><return_msg><![CDATA[%s]]></return_msg></xml>";

    public static String success(String msg) {
        return SUCCESS;
    }

    public static String fail(String msg) {
        return String.format(FAIL, msg);
    }
}

微信H5支付

微信H5支付是指在移动端网页上进行支付。在 Spring Boot 中整合微信H5支付,我们需要使用 WxPayService 对象来进行支付。

首先,我们需要在配置类中注入 WxPayService 对象:

@Configuration
public class WxPayConfig {

    @Value("${wx.pay.app-id}")
    private String appId;

    @Value("${wx.pay.mch-id}")
    private String mchId;

    @Value("${wx.pay.mch-key}")
    private String mchKey;

    @Value("${wx.pay.key-path}")
    private String keyPath;

    @Value("${wx.pay.notify-url}")
    private String notifyUrl;

    @Bean
    public WxPayService wxPayService() throws Exception {
        WxPayConfig wxPayConfig = new WxPayConfig();
        wxPayConfig.setAppId(appId);
        wxPayConfig.setMchId(mchId);
        wxPayConfig.setMchKey(mchKey);
        wxPayConfig.setKeyPath(keyPath);

        WxPayService wxPayService = new WxPayServiceImpl();
        wxPayService.setConfig(wxPayConfig);
        wxPayService.setPayConfig(wxPayConfig);
        // 注册异步通知处理器
        wxPayService.setNotifyUrl(notifyUrl, "/notify");
        return wxPayService;
    }
}

然后,我们就可以在控制器中使用 WxPayService 对象来进行支付了:

@RestController
public class PayController {

    @Autowired
    private WxPayService wxPayService;

    @PostMapping("/pay")
    public String pay(@RequestBody PayRequest payRequest) throws Exception {
        // 构造订单信息
        WxPayUnifiedOrderRequest orderRequest = new WxPayUnifiedOrderRequest();
        orderRequest.setBody(payRequest.getSubject());
        orderRequest.setOutTradeNo(payRequest.getOrderId());
        orderRequest.setTotalFee(payRequest.getAmount().intValue());
        orderRequest.setSpbillCreateIp(payRequest.getClientIp());
        orderRequest.setNotifyUrl(notifyUrl);
        orderRequest.setTradeType(WxPayConstants.TradeType.MWEB);
        orderRequest.setSceneInfo("{\"h5_info\":{\"type\":\"Wap\",\"wap_url\":\"http://www.example.com\",\"wap_name\":\"Example网站\"}}");

        // 调用统一下单接口
        WxPayMwebOrderResult orderResult = wxPayService.createOrder(orderRequest);

        // 获取支付跳转链接
        String mwebUrl = orderResult.getMwebUrl();
        return mwebUrl;
    }
    	
  	@PostMapping("/notify")
    public String notify(@RequestBody String xmlData) throws Exception {
        WxPayOrderNotifyResult notifyResult = wxPayService.parseOrderNotifyResult(xmlData);
        if (!WxPayConstants.ResultCode.SUCCESS.equals(notifyResult.getResultCode())) {
            // 支付失败,处理失败逻辑
            return WxPayNotifyResponse.fail("支付失败");
        }
        // 支付成功,处理成功逻辑
        String orderId = notifyResult.getOutTradeNo();
        // 更新订单状态等业务逻辑
        return WxPayNotifyResponse.success("OK");
    }
}

在这里,我们将 tradeType 参数设置为 WxPayConstants.TradeType.MWEB,表示使用H5支付方式。我们还设置了 sceneInfo 参数,它包含了 H5 支付的相关信息,比如 H5 网页的 URL 和名称。

注意,微信H5支付跳转链接的有效期为5分钟,所以在获取到跳转链接后应该尽快让用户跳转到支付页面。

总结

本文介绍了如何在 Spring Boot 中整合微信支付,包括微信公众号支付、微信APP支付、微信H5支付和微信扫码支付。我们使用了 WxPayService 对象来与微信支付接口进行交互,并在支付控制器中使用 WxPayService 对象来生成各种支付产品的支付参数或支付链接。在实际应用中,我们可以根据业务需求选择相应的支付产品和支付方式。

当然,本文只是简单介绍了微信支付的整合过程,实际的业务场景中可能还需要考虑一些其他因素,例如订单状态的处理、支付回调通知的处理等等。在实际开发中,我们还需要根据具体业务场景进行相应的定制化开发。

总的来说,通过本文的介绍,我们可以对 Spring Boot 中整合微信支付有一个基本的了解,并且可以快速上手进行开发。

标签:SpringBoot,String,微信,wxPayService,private,支付,orderRequest
From: https://blog.51cto.com/loveddz/6151270

相关文章

  • 微信小程序累计独立访客(UV)不低于 1000 是什么意思
    首先微信小程序“累计独立访客(UV)不低于1000”是指UV是UniqueVisitor的英文缩写,1天内相同的访客多次访问您的网站只计算1个UV,以cookie为依据。简单的说就是指:累计的不同IP的访客合计达到1000+才能开通流量主独立访客(UV)名词:UV=UniqueVisitor(独立访客数)说明:1天内相同的访客多......
  • 微信小程序i18n文件夹新增语言文件报:module is not defined
    背景:微信开发者工具的版本:1.06.2303060Stable 解决步骤:1.首先需要排除的是代码逻辑层面没有问题,对应要require的js文件也存在。2.升级微信开发者工具到最新版本3.打开详情=》本地设置,把“将JS编译成ES5”的去掉勾选后再次选择4.重新打开项目......
  • 1-SpringBoot快速入门
    SpringBoot快速入门1.什么是SpringBoot回顾什么是Spring?Spring是一个开源框架,2003年兴起的一个轻量级的Java开发框架,作者:RodJohnson。Spring是为了解决企业级应用开发的复杂性而创建的,简化开发。Spring是如何简化Java开发的?为了降低Java开发的复杂性,Spring采用......
  • 使用SpringBoot异步方法优化报销单查询接口,提高接口响应速度
    合理使用异步方法可以提高接口性能。异步方法适用于逻辑与逻辑之间可以相互分割互不影响的业务中。SpringBoot支持异步方法调用。具体用法:在启动类添加@EnableAsync注解,声明开启异步方法在异步方法添加@Async注解,被@Async注解修改的方法由SpringBoot默认线程池(SimpleAsyncTas......
  • 分析微信好友数据,可以可视化好友男女比例分布,可视化省份来源,可视化签名的情感强度值
    一、分析数据可视化好友男女分布比例 1plt.rcParams['font.sans-serif']=['SimHei']2#用来正常显示中文标签3plt.rcParams['axes.unicode_minus']=False45#1.读取csv文件,把性别信息读取出来6defgetSex(filename):7lstsex=[]8withopen(fi......
  • ChatGPT 微信接入 C#完整源码
    1.无需搭建服务器,操作极其简单。  2.winform运行程序扫码进行微信登录,勾上自动回复,就可以充当机器人调用chatGPT可实现自动回复,可以申请小号操作。  3.可以识别会话消息和群聊消息,拉入群聊@机器人可以进行群聊的消息回复,可以得到@自己的回复消息。4.代码是完整的也......
  • 微信开发:个人页面
    微信开发:个人页面wxml:<!--用户列表选项--><scroll-viewclass="scbg"scroll-y='true'><viewclass="parent_catainer"><!--头部--><!--style="background-image:url('/images/persons/mind_hea......
  • “支票”支付Zipmark发布App开发商移动支付平台
    有些人或许还没听过Zipmark,这相当于支票,只是并非纸质,也不用去银行,为用户支票转账提供简单便捷的服务,不论是收还是汇款,公司都会为用户提供一种无缝体验。手续费非常低,每笔交易收1%手续费,若金额较大,无论多少都5美金封顶。Zipmark今日发布移动支付开发商平台及API,商家或App开发......
  • 微信小程序使用 wxs 对模板数据格式化展示
    在小程序页面展示时,对时间、金额进行格式化处理。但是每次在js文件中处理,并setData感觉无比麻烦。是否可以直接在wxml模板文件中进行处理。正好发现了微信小程序wxs,完全满足需求。微信小程序wxs使用场景WXS(WeiXinScript)是微信创造的一套脚本语言,虽然看起来很JS异常......
  • SpringBoot中如何动态加载类到容器
    任何业务脱离场景无任何实际意义。场景:1,实现了多种存储方式,redis和本地内存或者其它,但是你希望根据注解配置只加载一种类到容器。2,经典场景:mybatis将接口的代理类动态加载到容器。分类:静态加载:1,springboot中会扫描同包路径下的(@configuration@Service@Component)标记了上述......