news 2026/2/11 8:25:59

Springboot集成支付宝

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Springboot集成支付宝

1、支付宝开放平台操作

我们需要做内网穿透,推荐使用 ngrok | API Gateway, Kubernetes Ingress, Webhook Gateway

详细接口参考API - 开放平台

进入 控制台首页 - 开放平台,开通沙箱环境

支付宝公钥,和你的秘钥点击查看就能看到

2、Springboot项目集成

1、添加依赖

添加支付宝sdk依赖和糊涂工具包

<dependency> <groupId>com.alipay.sdk</groupId> <artifactId>alipay-sdk-java</artifactId> <version>4.22.110.ALL</version> </dependency> <dependency> <groupId>cn.hutool</groupId> <artifactId>hutool-all</artifactId> <version>5.8.25</version> </dependency>

2、配置文件添加

alipay: # 应用ID app-id: 你的APPID # 商户私钥 merchant-private-key: 你的私钥 # 支付宝公钥 alipay-public-key: 支付宝公钥 # 网关地址 gateway-url: https://openapi.alipay.com/gateway.do # 回调地址(需公网可访问) notify-url: https://your-domain.com/alipay/notify return-url: https://your-domain.com/alipay/return # 签名方式 sign-type: RSA2 charset: UTF-8 format: JSON

3、代码实现

配置类

package com.jha.springcloudlearn.entity; import com.alipay.api.AlipayClient; import com.alipay.api.DefaultAlipayClient; import org.springframework.beans.factory.annotation.Value; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; @Configuration public class AlipayConfig { @Value("${alipay.app-id}") private String appId; @Value("${alipay.merchant-private-key}") private String privateKey; @Value("${alipay.alipay-public-key}") private String alipayPublicKey; @Value("${alipay.gateway-url}") private String gatewayUrl; @Value("${alipay.sign-type}") private String signType; @Value("${alipay.charset}") private String charset; @Value("${alipay.format}") private String format; @Bean public AlipayClient alipayClient() { return new DefaultAlipayClient( gatewayUrl, appId, privateKey, format, charset, alipayPublicKey, signType ); } }

支付服务类

package com.jha.springcloudlearn.service.impl; import com.alipay.api.AlipayClient; import com.alipay.api.domain.AlipayTradePagePayModel; import com.alipay.api.request.AlipayTradePagePayRequest; import com.alipay.api.response.AlipayTradePagePayResponse; import lombok.AllArgsConstructor; import lombok.Data; import lombok.NoArgsConstructor; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Value; import org.springframework.stereotype.Service; import java.math.BigDecimal; @Service public class AlipayService { @Autowired private AlipayClient alipayClient; @Value("${alipay.notify-url}") private String notifyUrl; @Value("${alipay.return-url}") private String returnUrl; /** * 电脑网站支付 */ public String pagePay(AlipayOrder order) throws Exception { AlipayTradePagePayRequest request = new AlipayTradePagePayRequest(); // 设置异步通知地址 request.setNotifyUrl(notifyUrl); // 设置同步通知地址 request.setReturnUrl(returnUrl); AlipayTradePagePayModel model = new AlipayTradePagePayModel(); model.setOutTradeNo(order.getOutTradeNo()); model.setTotalAmount(order.getTotalAmount().toString()); model.setSubject(order.getSubject()); model.setBody(order.getBody()); model.setProductCode("FAST_INSTANT_TRADE_PAY"); request.setBizModel(model); AlipayTradePagePayResponse response = alipayClient.pageExecute(request); if (response.isSuccess()) { return response.getBody(); } else { throw new RuntimeException("支付宝支付调用失败"); } } /** * 订单实体类 */ @Data @AllArgsConstructor @NoArgsConstructor public static class AlipayOrder { private String outTradeNo; // 商户订单号 private BigDecimal totalAmount; // 订单金额 private String subject; // 订单标题 private String body; // 订单描述 } }

支付控制器

package com.jha.springcloudlearn.controller; import cn.hutool.json.JSONObject; import com.alipay.api.AlipayApiException; import com.alipay.api.internal.util.AlipaySignature; import com.alipay.api.request.AlipayTradeQueryRequest; import com.jha.springcloudlearn.service.impl.AlipayService; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Value; import org.springframework.web.bind.annotation.*; import javax.servlet.http.HttpServletResponse; import java.io.IOException; import java.util.Map; @RestController @RequestMapping("/alipay") public class AlipayController { @Autowired private AlipayService alipayService; @Value("${alipay.alipay-public-key}") private String alipayPublicKey; @Value("${alipay.charset}") private String charset; @Value("${alipay.sign-type}") private String signType; /** * 发起支付 */ @PostMapping("/pay") public void pay(@RequestBody AlipayService.AlipayOrder orderDTO, HttpServletResponse response) throws Exception { AlipayService.AlipayOrder order = new AlipayService.AlipayOrder( orderDTO.getOutTradeNo(), orderDTO.getTotalAmount(), orderDTO.getSubject(), orderDTO.getBody() ); String form = alipayService.pagePay(order); // 直接将表单输出到浏览器 response.setContentType("text/html;charset=UTF-8"); response.getWriter().write(form); response.getWriter().flush(); response.getWriter().close(); } /** * 支付宝异步通知回调 */ @PostMapping("/notify") public String notifyUrl(@RequestParam Map<String, String> params) { try { // 验证签名 boolean signVerified = AlipaySignature.rsaCheckV1( params, alipayPublicKey, charset, signType ); if (!signVerified) { return "failure"; } // 处理业务逻辑 String tradeStatus = params.get("trade_status"); String outTradeNo = params.get("out_trade_no"); String tradeNo = params.get("trade_no"); if ("TRADE_SUCCESS".equals(tradeStatus) || "TRADE_FINISHED".equals(tradeStatus)) { // 更新订单状态为已支付 return "success"; } return "failure"; } catch (Exception e) { return "failure"; } } /** * 支付成功同步回调 */ @GetMapping("/return") public String returnUrl(@RequestParam Map<String, String> params) { // 这里通常显示支付成功页面,实际订单状态以异步通知为准 return "支付成功!订单号:" + params.get("out_trade_no"); } /** * 订单查询 */ @GetMapping("/query") public String queryOrder(String outTradeNo) throws AlipayApiException { AlipayTradeQueryRequest request = new AlipayTradeQueryRequest(); JSONObject bizContent = new JSONObject(); bizContent.put("out_trade_no", outTradeNo); request.setBizContent(bizContent.toString()); return null; } }

支付回调验证工具类

package com.jha.springcloudlearn.controller; import com.alipay.api.AlipayApiException; import com.alipay.api.AlipayClient; import com.alipay.api.internal.util.AlipaySignature; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Value; import org.springframework.stereotype.Component; import java.util.Map; @Component public class AlipayNotifyHandler { @Value("${alipay.alipay-public-key}") private String alipayPublicKey; @Value("${alipay.charset}") private String charset; @Value("${alipay.sign-type}") private String signType; /** * 验证支付宝回调的签名 */ public boolean verifySignature(Map<String, String> params) { try { return AlipaySignature.rsaCheckV1( params, alipayPublicKey, charset, signType ); } catch (AlipayApiException e) { return false; } } }

这样就能接入了支付宝了

3、测试

运行我们的项目,然后使用接口工具进行测试

1、获取表单

得到的出参就是一个form表单,正常来说由前端那边去做接受然后处理,这边我们就自己把他放到html中去做后续支付操作

2、构建html

<!-- 将返回的HTML代码保存为 .html 文件 --> <!DOCTYPE html> <html> <head> <title>支付宝支付</title> </head> <body> <!-- 返回的form表单复制到下面,并运行即可 --> </body> </html>

3、支付流程

打开html之后,出现如下页面

这里扫码支付暂时是不行的,因为我们使用的是沙箱,所以使用账号登录

账号在如下图所示位置

输入账户密码之后,跳转到另一个支付页面

输入支付密码之后,进行确认付款即可

然后就是跳转到成功支付的页面,然后再调用我们的回调函数

这样支付宝就接入成功了,后续可以加入自己个性化的东西,如订单操作等

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/7 9:41:15

如何用ChatGPT提升开发效率?实战技巧大公开

ChatGPT在软件测试中的效率革命 随着AI技术的快速发展&#xff0c;ChatGPT正成为测试工程师的智能协作者。本文聚焦六大核心场景&#xff0c;结合可落地的操作指南&#xff0c;帮助测试人员将AI能力深度融入工作流。 一、智能测试用例生成&#xff1a;覆盖度提升300%的秘诀 1…

作者头像 李华
网站建设 2026/2/10 21:24:55

JavaScript 数组合并性能优化:扩展运算符 vs concat vs 循环 push

在日常开发中&#xff0c;我们经常需要合并数组&#xff0c;比如批量导入数据、分页加载列表、处理大量日志等场景。当数组规模较小时&#xff0c;用什么方法都差不多&#xff1b;但当数组达到成千上万条时&#xff0c;选择不当的方法可能会导致栈溢出或内存飙升。 今天我们就…

作者头像 李华
网站建设 2026/2/5 7:12:04

python项目打包为镜像

1.生成 requirements.txt 在项目根目录下,使用 pipreqs生成依赖文件,确保镜像构建时安装正确的包 pip install pipreqs pipreqs . --encoding=utf8 --force 2.编写 Dockerfile # 使用官方 Python 轻量级镜像 FROM python:3.11-slim# 设置容器内工作目录 WORKDIR /app# 复制…

作者头像 李华
网站建设 2026/2/3 14:35:41

Spark Streaming与大数据批处理的结合应用

Spark Streaming与大数据批处理的结合应用:实时与离线的完美搭档 关键词:Spark Streaming、大数据批处理、流批结合、实时计算、离线分析 摘要:在大数据时代,企业既需要实时掌握业务动态(比如用户刚下单的商品),也需要挖掘历史规律(比如过去一年的销售趋势)。Spark St…

作者头像 李华
网站建设 2026/2/8 3:30:14

优化提示内容交互设计的9个实用技巧

优化提示内容交互设计的9个实用技巧&#xff1a;让AI更懂你的“说话之道” 一、引入与连接&#xff1a;为什么你需要学“提示设计”&#xff1f; 清晨&#xff0c;你打开ChatGPT&#xff0c;输入&#xff1a;“帮我写篇关于秋天的文章。”半小时后&#xff0c;你看着屏幕上那篇…

作者头像 李华
网站建设 2026/2/11 2:24:53

欧姆龙CP1H + CIF11与欧姆龙E5cc温控器通讯程序分享

欧姆龙CP1HCIF11与欧姆龙E5cc温控器通讯程序 功能&#xff1a;全新原创可直接应用生产程序。 通过昆仑通态触摸屏&#xff0c;串口网关模式&#xff0c;欧姆龙CP1H的CIF11通讯板&#xff0c;实现对欧姆龙E5CC温控器 设定温度值&#xff0c;读取实际温度&#xff0c;设定探头类型…

作者头像 李华