Spring Boot 集成支付宝、微信等支付平台API

Spring Boot 集成支付宝、微信等支付平台API

在现代的 Web 应用程序开发中,与第三方 API 的集成是非常常见的需求。例如,支付宝、微信等支付平台的支付接口、短信验证码的发送接口、邮件发送接口等。Spring Boot 提供了许多便捷的方式来集成这些第三方 API,本文将介绍如何在 Spring Boot 中集成支付宝和微信支付接口。

在这里插入图片描述

集成支付宝支付接口

1. 准备工作

在开始之前,我们需要先注册一个支付宝开发者账号,并且创建一个应用。创建应用的过程中,我们需要获取到应用的 APP_IDAPP_PRIVATE_KEYALIPAY_PUBLIC_KEY 三个值,这些值将在后面的代码中使用。

2. 添加依赖

pom.xml 文件中添加以下依赖:

<dependency>
    <groupId>com.alipay.sdk</groupId>
    <artifactId>alipay-sdk-java</artifactId>
    <version>4.16.1046.ALL</version>
</dependency>

3.编写代码

3.1 初始化支付宝客户端

在代码中初始化支付宝客户端,代码如下:

import com.alipay.api.AlipayClient;
import com.alipay.api.DefaultAlipayClient;

public class AliPayUtil {
    private static final String APP_ID = "your_app_id";
    private static final String APP_PRIVATE_KEY = "your_app_private_key";
    private static final String ALIPAY_PUBLIC_KEY = "alipay_public_key";
    private static final String CHARSET = "UTF-8";
    private static final String GATEWAY_URL = "https://openapi.alipay.com/gateway.do";

    public static AlipayClient getAlipayClient() {
        return new DefaultAlipayClient(GATEWAY_URL, APP_ID, APP_PRIVATE_KEY, "json", CHARSET, ALIPAY_PUBLIC_KEY, "RSA2");
    }
}
3.2 发起支付请求

在代码中发起支付请求,代码如下:

import com.alipay.api.AlipayApiException;
import com.alipay.api.AlipayClient;
import com.alipay.api.request.AlipayTradePagePayRequest;
import com.alipay.api.response.AlipayTradePagePayResponse;

public class AliPayUtil {
    // 省略上面的代码

    public static String pay(String outTradeNo, String totalAmount, String subject, String returnUrl) throws AlipayApiException {
        AlipayClient alipayClient = getAlipayClient();

        AlipayTradePagePayRequest request = new AlipayTradePagePayRequest();
        request.setReturnUrl(returnUrl);
        request.setNotifyUrl("your_notify_url");

        request.setBizContent("{\"out_trade_no\":\"" + outTradeNo + "\","
                + "\"total_amount\":\"" + totalAmount + "\","
                + "\"subject\":\"" + subject + "\","
                + "\"product_code\":\"FAST_INSTANT_TRADE_PAY\"}");

        AlipayTradePagePayResponse response = alipayClient.pageExecute(request);
        return response.getBody();
    }
}

在上面的代码中,我们首先获取了一个 AlipayClient 对象,该对象需要传入 GATEWAY_URLAPP_IDAPP_PRIVATE_KEYALIPAY_PUBLIC_KEY 等参数来初始化。然后我们构造了一个 AlipayTradePagePayRequest 对象,该对象包含了我们需要支付的订单信息,如 out_trade_no(订单号)、total_amount(订单金额)、subject(订单标题)等等。最后,我们通过 alipayClient.pageExecute(request) 方法发起了支付请求,并且返回了支付宝的响应结果。

4. 整合到 Spring Boot 项目中

我们可以将上面的代码整合到 Spring Boot 项目中,使得我们可以在 Spring Boot 应用程序中方便地使用支付宝支付接口。下面是整合到 Spring Boot 的代码:

import com.alipay.api.AlipayApiException;
import com.alipay.api.AlipayClient;
import com.alipay.api.DefaultAlipayClient;
import com.alipay.api.request.AlipayTradePagePayRequest;
import com.alipay.api.response.AlipayTradePagePayResponse;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;

@Component
public class AliPayUtil {
    @Value("${alipay.appId}")
    private String appId;

    @Value("${alipay.privateKey}")
    private String privateKey;

    @Value("${alipay.publicKey}")
    private String publicKey;

    @Value("${alipay.charset}")
    private String charset;

    @Value("${alipay.gatewayUrl}")
    private String gatewayUrl;

    @Value("${alipay.returnUrl}")
    private String returnUrl;

    public AlipayClient getAlipayClient() {
        return new DefaultAlipayClient(gatewayUrl, appId, privateKey, "json", charset, publicKey, "RSA2");
    }

    public String pay(String outTradeNo, String totalAmount, String subject) throws AlipayApiException {
        AlipayClient alipayClient = getAlipayClient();

        AlipayTradePagePayRequest request = new AlipayTradePagePayRequest();
        request.setReturnUrl(returnUrl);
        request.setNotifyUrl("your_notify_url");

        request.setBizContent("{\"out_trade_no\":\"" + outTradeNo + "\","
                + "\"total_amount\":\"" + totalAmount + "\","
                + "\"subject\":\"" + subject + "\","
                + "\"product_code\":\"FAST_INSTANT_TRADE_PAY\"}");

        AlipayTradePagePayResponse response = alipayClient.pageExecute(request);
        return response.getBody();
    }
}

在上面的代码中,我们使用了 Spring Boot 的 @Value 注解来从 application.properties 文件中获取配置信息,这些配置信息包括 appIdprivateKeypublicKeycharsetgatewayUrlreturnUrl 等等。然后我们将 AliPayUtil 类声明为 Spring Boot 的 @Component,这样我们就可以在其他 Spring Bean 中使用它了。

集成微信支付接口

1. 准备工作

在开始之前,我们需要先注册一个微信支付商户账号,并且创建一个应用。创建应用的过程中,我们需要获取到应用的 APP_IDMCH_IDAPI_KEY 三个值,这些值将在后面的代码中使用。

2. 添加依赖

pom.xml 文件中添加以下依赖:

<dependency>
    <groupId>com.github.wxpay</groupId>
    <artifactId>wxpay-sdk</artifactId>
    <version>3.0.10</version>
</dependency>

3. 编写代码

3.1 初始化微信支付客户端

在代码中初始化微信支付客户端,代码如下:

import com.github.wxpay.sdk.WXPay;
import com.github.wxpay.sdk.WXPayConfigImpl;

import java.io.InputStream;

public class WxPayUtil {
    private static final String APP_ID = "your_app_id";
    private static final String MCH_ID = "your_mch_id";
    private static final String API_KEY = "your_api_key";

    public static WXPay getWXPay() throws Exception {
        InputStream inputStream = WxPayUtil.class.getResourceAsStream("/cert/apiclient_cert.p12");
        WXPayConfigImpl wxPayConfig = WXPayConfigImpl.getInstance(APP_ID, MCH_ID, API_KEY, inputStream);

        return new WXPay(wxPayConfig);
    }
}

在上面的代码中,我们首先获取了一个 InputStream 对象,该对象是我们在微信支付商户平台上下载的证书文件,用于证明我们的身份。然后我们构造了一个 WXPayConfigImpl 对象,该对象需要传入 APP_IDMCH_IDAPI_KEY 等参数来初始化,同时还需要传入证书文件的 InputStream。最后,我们通过 new WXPay(wxPayConfig) 方法获取了一个 WXPay 对象。

3.2 发起支付请求

在代码中发起支付请求,代码如下:

import com.github.wxpay.sdk.WXPay;
import com.github.wxpay.sdk.WXPayUtil;

import java.util.HashMap;
import java.util.Map;

public class WxPayUtil {
    // 省略上面的代码

    public static Map<String, String> pay(String outTradeNo, String totalFee, String body, String spbillCreateIp) throws Exception {
        WXPay wxPay = getWXPay();

        Map<String, String> data = new HashMap<>();
        data.put("body", body);
        data.put("out_trade_no", outTradeNo);
        data.put("device_info", "");
        data.put("fee_type", "CNY");
        data.put("total_fee", totalFee);
        data.put("spbill_create_ip", spbillCreateIp);
        data.put("notify_url", "your_notify_url");
        data.put("trade_type", "NATIVE");

        Map<String, String> response = wxPay.unifiedOrder(data);
        if ("SUCCESS".equals(response.get("return_code")) && "SUCCESS".equals(response.get("result_code"))) {
            return response;
        } else {
            throw new Exception(response.get("return_msg"));
        }
    }
}

在上面的代码中,我们首先获取了一个 WXPay 对象,该对象需要传入 APP_IDMCH_IDAPI_KEY 等参数来初始化,同时还需要传入证书文件的 InputStream。然后我们构造了一个 data 对象,该对象包含了我们需要支付的订单信息,如 body(商品描述)、out_trade_no(订单号)、fee_type(货币类型)、total_fee(订单金额)、spbill_create_ip(终端IP)等等。最后,我们通过 wxPay.unifiedOrder(data) 方法发起了支付请求,并且返回了微信支付的响应结果。

4. 整合到 Spring Boot 项目中

我们可以将上面的代码整合到 Spring Boot 项目中,使得我们可以在 Spring Boot 应用程序中方便地使用微信支付接口。下面是整合到 Spring Boot 的代码:

import com.github.wxpay.sdk.WXPay;
import com.github.wxpay.sdk.WXPayConfigImpl;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.core.io.Resource;
import org.springframework.stereotype.Component;

import java.io.InputStream;
import java.util.HashMap;
import java.util.Map;

@Component
public class WxPayUtil {
    @Value("${wxpay.appId}")
    private String appId;

    @Value("${wxpay.mchId}")
    private String mchId;

    @Value("${wxpay.apiKey}")
    private String apiKey;

    @Value("${wxpay.certPath}")
    private Resource certPath;

    public WXPay getWXPay() throws Exception {
        InputStream inputStream = certPath.getInputStream();
        WXPayConfigImpl wxPayConfig = WXPayConfigImpl.getInstance(appId, mchId, apiKey, inputStream);

        return new WXPay(wxPayConfig);
    }

    public Map<String, String> pay(String outTradeNo, String totalFee, String body, String spbillCreateIp) throws Exception {
        WXPay wxPay = getWXPay();

        Map<String, String> data = new HashMap<>();
        data.put("body", body);
        data.put("out_trade_no", outTradeNo);
        data.put("device_info", "");
        data.put("fee_type", "CNY");
        data.put("total_fee", totalFee);
        data.put("spbill_create_ip", spbillCreateIp);
        data.put("notify_url", "your_notify_url");
        data.put("trade_type", "NATIVE");

        Map<String, String> response = wxPay.unifiedOrder(data);
        if ("SUCCESS".equals(response.get("return_code")) && "SUCCESS".equals(response.get("result_code"))) {
            return response;
        } else {
            throw new Exception(response.get("return_msg"));
        }
    }
}

在上面的代码中,我们使用了 Spring Boot 的 @Value 注解来从 application.properties 文件中获取配置信息,这些配置信息包括 appIdmchIdapiKeycertPath 等等。然后我们将 WxPayUtil 类声明为 Spring Boot 的 @Component,这样我们就可以在其他 Spring Bean 中使用它了。

结论

在本文中,我们介绍了如何在 Spring Boot 中集成支付宝和微信支付接口。我们首先介绍了如何初始化支付宝和微信支付客户端,然后介绍了如何发起支付请求。最后,我们将这些代码整合到了 Spring Boot 项目中,使得我们可以在 Spring Boot 应用程序中方便地使用支付宝和微信支付接口。

值得一提的是,本文中的代码仅仅是支付接口调用的基础示例,实际在生产环境中,我们需要更多的安全措施,例如在支付请求中添加签名信息、验证支付结果的签名信息等等。同时,我们也需要考虑支付过程中可能出现的异常情况,例如支付超时、支付失败等等,以及如何处理这些异常情况。

总之,集成第三方 API 是一个经常出现的需求,我们需要掌握相关的技能来满足这个需求。希望本文可以帮助你更好地理解在 Spring Boot 中集成支付宝和微信支付接口的基本流程。

  • 2
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Spring Boot框架提供了强大的集成能力,可以很容易地将微信支付支付支付集成到一个二维码支付系统中。 首先,我们需要添加相关的依赖项。对于微信支付,我们可以使用微信支付Java SDK,而对于支付支付,我们可以使用支付支付SDK。通过在pom.xml文件中添加相应的依赖项,我们可以将它们导入我们的项目中。 在Spring Boot中,我们可以使用@Controller注解创建一个控制器类来接受支付请求。我们可以创建一个API端点,当接收到支付请求时,生成一个包含支付信息的二维码。对于微信支付,我们可以使用微信支付SDK提供的API来生成一个微信支付二维码;对于支付支付,我们可以使用支付支付SDK提供的API来生成一个支付支付二维码。 将生成的二维码展示给用户后,用户可以扫描并完成支付。我们可以创建一个回调接口来接收支付结果通知,并根据支付结果来更新订单状态。 在Spring Boot中,我们可以使用@NotifyMapping注解创建一个消息回调处理器,用于接收支付结果通知。对于微信支付,我们可以使用微信支付SDK提供的回调处理方法;对于支付支付,我们可以使用支付支付SDK提供的回调处理方法。 最后,我们可以使用Spring Boot的日志记录功能来记录支付过程中产生的日志信息,以便后续进行排查和分析。 综上所述,Spring Boot提供了一个简单而强大的集成能力,可以轻松地将微信支付支付支付集成到一个二维码支付系统中。通过使用相应的SDK和技术,我们可以实现一张二维码同时集成微信支付支付的功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

IT徐师兄

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值