SpringBoot集成支付宝沙箱支付的实现示例

 更新时间:2021年12月23日 14:31:56   作者:一吃就胖的小李  
本文主要介绍了SpringBoot集成支付宝沙箱支付的实现示例,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

开发前准备

1、密钥工具

在线工具地址:https://miniu.alipay.com/keytool/create
无需下载,直接在线生成你的应用私钥


点击生成即可生成自己的公钥和私钥
这个公钥后面会用到叫做alipayPublicKey
这个私钥后面会用到叫做appPrivateKey

如果遇到生成失败点击链接选择Web在线加密https://opendocs.alipay.com/open/291/introduce

在这里插入图片描述

再不行就自己下载客户端工具

2、沙箱环境

注册支付宝开发者账户,进入开发者控制台
https://auth.alipay.com/login/ant_sso_index.htm?goto=https%3A%2F%2Fopenhome.alipay.com%2Fplatform%2FdeveloperIndex.htm

在这里插入图片描述

在这里插入图片描述

这个appid后面配置springboot会用到

在这里插入图片描述

这里的公钥就是上面生成的,不要填错了

3、内网穿透工具

我用的是natapp,下载地址:https://natapp.cn/
启动命令:natapp.exe -authtoken=你的authtoken 这个authtoken是在natapp里面创建免费隧道产生的。
注意隧道的端口要配置成你的后台端口,例如9090

在这里插入图片描述

在这里插入图片描述

直接在上面的命令后面加上就可以启动你的 natapp,设置内网穿透了。

内网穿透就是把本机的 ip 和端口暴露到外网,通过指定的 url 可以访问你本地的服务,当然 ,这存在一定的安全风险,请谨慎使用!使用命令开启 natapp 后,会生成一个外网的地址指向你本地的服务地址,当你访问http://tdqxnr.natappfree.cc,跟你访问 127.0.0.1:9090 效果是一样的,只不过一个是对外的,一个是只能本地访问。

在这里插入图片描述

代码集成

1、Java SDK

打开支付宝官方文档:https://opendocs.alipay.com/open/54/00y8k9
他提供了一个Easy版本的Java SDK集成方案,我们可以直接用这个。

在这里插入图片描述

maven依赖:

<dependency>
 <groupId>com.alipay.sdk</groupId>
 <artifactId>alipay-easysdk</artifactId>
 <version>2.2.0</version>
</dependency>

2、支付宝配置

application.properties 文件里面加上这些配置,appId 就是上面看到的沙箱环境里面提
供的appId,appPrivateKey 和 alipayPublicKey也是上面已经有了,直接复制过来即可。
notifyUrl是支付成功后的一个回调接口,用来修改订单的状态,我们可以在
AliPayController 加上这个接口(后面有讲到),注意,这个回调接口的地址必须是我们在
natapp 里面获取到的公网地址,否则接口无法回调。

在这里插入图片描述

新建一个配置类AliPayConfig

package com.example.demo.common.config;

import com.alipay.easysdk.factory.Factory;
import com.alipay.easysdk.kernel.Config;
import lombok.Data;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.stereotype.Component;

import javax.annotation.PostConstruct;

@Data
@Component
@ConfigurationProperties(prefix = "alipay")
public class AliPayConfig {
    private String appId;
    private String appPrivateKey;
    private String alipayPublicKey;
    private String notifyUrl;


    @PostConstruct
    public void init() {
        // 设置参数(全局只需设置一次)
        Config options = getOptions();
        options.appId = this.appId;
        options.merchantPrivateKey = this.appPrivateKey;
        options.alipayPublicKey = this.alipayPublicKey;
        options.notifyUrl = this.notifyUrl;
        Factory.setOptions(options);
        System.out.println("=======支付宝SDK初始化成功=======");
    }

    private Config getOptions() {
        Config config = new Config();
        config.protocol = "https";
        config.gatewayHost = "openapi.alipaydev.com";
        config.signType = "RSA2";
        return config;
    }

}

注意:在拦截器里面加上忽略alipay接口的配置!

在这里插入图片描述

3、支付和回调接口

新建一个 AliPayController,写一个 Get 接口,这个是支付的接口,前端需要把 订单的标
题、订单编号、订单的总金额传到后台来,后台去调用支付宝的 APi 生成支付订单,在网页上
实现支付。

 @GetMapping("/pay")
    public String pay(AliPay aliPay) {
        AlipayTradePagePayResponse response;
        try {
            //  发起API调用(以创建当面付收款二维码为例)
            response = Factory.Payment.Page()
                    .pay(aliPay.getSubject(), aliPay.getTraceNo(), aliPay.getTotalAmount(), "");
        } catch (Exception e) {
            System.err.println("调用遭遇异常,原因:" + e.getMessage());
            throw new RuntimeException(e.getMessage(), e);
        }
        return response.getBody();
    }

第二个接口是支付成功回调的接口,我们在这个接口可以获取到支付订单的订单编号和支付时
间,然后我们可以修改本地订单的支付状态。注意:这是一个 POST 接口。

@PostMapping("/notify")  // 注意这里必须是POST接口
    public String payNotify(HttpServletRequest request) throws Exception {
        if (request.getParameter("trade_status").equals("TRADE_SUCCESS")) {
            System.out.println("=========支付宝异步回调========");

            Map<String, String> params = new HashMap<>();
            Map<String, String[]> requestParams = request.getParameterMap();
            for (String name : requestParams.keySet()) {
                params.put(name, request.getParameter(name));
                // System.out.println(name + " = " + request.getParameter(name));
            }

            String tradeNo = params.get("out_trade_no");
            String gmtPayment = params.get("gmt_payment");

            // 支付宝验签
            if (Factory.Payment.Common().verifyNotify(params)) {
                // 验签通过
                System.out.println("交易名称: " + params.get("subject"));
                System.out.println("交易状态: " + params.get("trade_status"));
                System.out.println("支付宝交易凭证号: " + params.get("trade_no"));
                System.out.println("商户订单号: " + params.get("out_trade_no"));
                System.out.println("交易金额: " + params.get("total_amount"));
                System.out.println("买家在支付宝唯一id: " + params.get("buyer_id"));
                System.out.println("买家付款时间: " + params.get("gmt_payment"));
                System.out.println("买家付款金额: " + params.get("buyer_pay_amount"));

                // 更新订单未已支付
                orderMapper.updateState(tradeNo, 1, gmtPayment);
            }
        }
        return "success";
    }

4、前端Vue调用

在书籍的表格里,我加了个 购买的按钮用来测试支付功能。

在这里插入图片描述

点击购买按钮,会发生一次网络请求。请求后台的 OrderController 生成一个订单,并返
回调用 AliPayController 的调用地址:

在这里插入图片描述

@GetMapping("/buy/{bookId}")
    public Result<?> buy(@PathVariable Long bookId) {
        Book book = bookMapper.selectById(bookId);
        String orderNo = IdUtil.getSnowflake().nextIdStr();
        String payUrl = "http://localhost:9090/alipay/pay?subject=" + book.getName() + "&traceNo=" + orderNo + "&totalAmount=" + book.getPrice();

        User user = getUser();
        Order order = new Order();
        order.setOrderNo(orderNo);
        order.setTotalPrice(book.getPrice());
        order.setPayPrice(book.getPrice());
        order.setTransportPrice(BigDecimal.ZERO);
        order.setUserId(user.getId());
        order.setUsername(user.getUsername());
        order.setName(book.getName());
        save(order);
        // 新建订单,扣减库存
        return Result.success(payUrl);
    }

前端拿到这个地址,直接在新窗口打开即可出现支付宝的沙箱支付页面:

在这里插入图片描述

buy(bookId) {
      request.get("/order/buy/" + bookId).then(res => {
        // 请求成功跳转沙箱支付的页面
        window.open(res.data)
      })
    },

支付宝沙箱页面是这样的:

在这里插入图片描述

这里的账户和密码都是模拟的,可以在自己的沙箱账户里找到,地址:
https://openhome.alipay.com/platform/appDaily.htm?tab=account

在这里插入图片描述

账户是虚拟的,可以随意充值。

如果一不小心出现了下面的这个页面

在这里插入图片描述

别慌!你有 2 个选择:

打开一个新的浏览器,进入系统再次购买即可!关闭所有网页,清除缓存,重新进入购买页面,点击购买。

在这里插入图片描述

然后你输入上面看到的账户密码继续就行了:

在这里插入图片描述

支付密码也是 111111 ,点击确认付款

在这里插入图片描述

跳转到这个页面,表示支付成功

在这里插入图片描述

一定要注意:每次重启 natapp 都会重新生成新的外网地址,你需要在你的配置文件里面及
时更换,否则,无法回调!

到此这篇关于SpringBoot集成支付宝沙箱支付的实现示例的文章就介绍到这了,更多相关SpringBoot 支付宝沙箱支付内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Springboot集成第三方jar快速实现微信、支付宝等支付场景

    Springboot集成第三方jar快速实现微信、支付宝等支付场景

    这篇文章主要介绍了Springboot集成第三方jar快速实现微信、支付宝等支付场景,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-01-01
  • java调用Oracle存储过程的方法实例

    java调用Oracle存储过程的方法实例

    这篇文章介绍了java调用Oracle存储过程的方法实例,有需要的朋友可以参考一下
    2013-09-09
  • 快速学会Dubbo的配置环境及相关配置

    快速学会Dubbo的配置环境及相关配置

    本文主要讲解Dubbo的环境与配置,文中运用大量代码和图片讲解的非常详细,需要学习或用到相关知识的小伙伴可以参考这篇文章
    2021-09-09
  • mybatis判断list不为空/大小的问题

    mybatis判断list不为空/大小的问题

    这篇文章主要介绍了mybatis判断list不为空/大小的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-01-01
  • activemq整合springboot使用方法(个人微信小程序用)

    activemq整合springboot使用方法(个人微信小程序用)

    这篇文章主要介绍了activemq整合springboot使用(个人微信小程序用),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-03-03
  • 基于java中反射的总结分析

    基于java中反射的总结分析

    所谓反射,就是根据一个已经实例化了的对象来还原类的完整信息
    至少对我而言,我认为它带给我的好处是,让我从下往上的又了解了一遍面向对象

    2013-05-05
  • Java随机字符串与简单加密工具类详解

    Java随机字符串与简单加密工具类详解

    这篇文章主要介绍了Java随机字符串与简单加密工具类,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-11-11
  • Java中Synchronized锁的使用和原理详解

    Java中Synchronized锁的使用和原理详解

    这篇文章主要介绍了Java中Synchronized锁的使用和原理详解,synchronized是 Java 内置的关键字,它提供了一种独占的加锁方式,synchronized的获取和释放锁由JVM实现,用户不需要显示的释放锁,非常方便,需要的朋友可以参考下
    2023-07-07
  • swing重绘按钮为任意形状图案的方法

    swing重绘按钮为任意形状图案的方法

    这篇文章主要为大家详细介绍了swing重绘按钮为任意形状图案,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-12-12
  • springboot vue组件开发实现接口断言功能

    springboot vue组件开发实现接口断言功能

    这篇文章主要为大家介绍了springboot+vue组件开发实现接口断言功能,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-05-05

最新评论