在Spring Boot项目中接入支付宝扫码支付功能,可以通过以下步骤实现。以下是基于最新搜索结果的详细教程:
1. 支付宝扫码支付原理
支付宝扫码支付是一种用户通过扫描二维码完成支付的方式,适用于线下门店、自助终端等场景。其核心流程如下:
-
商家系统调用支付宝的预下单接口,生成支付二维码。
-
用户通过支付宝APP扫描二维码,确认支付。
-
支付成功后,支付宝通过异步通知告知商家系统支付结果。
2. 开发步骤
2.1 注册支付宝开放平台账号
-
访问支付宝开放平台(https://open.alipay.com),使用支付宝账号登录。
-
在“应用管理”中创建应用,获取
AppID
。
2.2 配置支付参数
在
application.yml
中配置支付宝参数:alipay:
easy:
protocol: https
gatewayHost: openapi.alipay.com
signType: RSA2
appId: your-app-id
merchantPrivateKey: your-private-key
alipayPublicKey: alipay-public-key
notifyUrl: http://your-domain/notify
2.3 引入依赖
在
pom.xml
中引入支付宝SDK和二维码生成工具库:<dependency>
<groupId>com.alipay.sdk</groupId>
<artifactId>alipay-sdk-java</artifactId>
<version>4.9.79.ALL</version>
</dependency>
<dependency>
<groupId>cn.hutool</groupId>
<artifactId>hutool-all</artifactId>
<version>5.7.22</version>
</dependency>
2.4 创建支付接口
创建支付服务类
AlipayService
,实现扫码支付功能:import com.alipay.api.AlipayClient;
import com.alipay.api.DefaultAlipayClient;
import com.alipay.api.request.AlipayTradePrecreateRequest;
import com.alipay.api.response.AlipayTradePrecreateResponse;
import cn.hutool.qr.QrCodeUtil;
@Service
public class AlipayService {
@Autowired
private Environment env;
public String createQrCode(String subject, String totalAmount) throws Exception {
AlipayClient alipayClient = new DefaultAlipayClient(
env.getProperty("alipay.easy.protocol"),
env.getProperty("alipay.easy.appId"),
env.getProperty("alipay.easy.merchantPrivateKey"),
"json",
"UTF-8",
env.getProperty("alipay.easy.alipayPublicKey"),
"RSA2");
AlipayTradePrecreateRequest request = new AlipayTradePrecreateRequest();
request.setBizContent("{"
+ "\"out_trade_no\":\"" + UUID.randomUUID().toString().replace("-", "") + "\","
+ "\"total_amount\":\"" + totalAmount + "\","
+ "\"subject\":\"" + subject + "\","
+ "\"product_code\":\"FACE_TO_FACE_PAYMENT\""
+ "}");
AlipayTradePrecreateResponse response = alipayClient.execute(request);
if (response.isSuccess()) {
String qrCodeUrl = response.getQrCode();
return qrCodeUrl; // 返回二维码链接
} else {
throw new RuntimeException("支付二维码生成失败:" + response.getMsg());
}
}
}
2.5 生成二维码
在Controller中调用支付服务,生成二维码并返回给前端:
@RestController
public class PayController {
@Autowired
private AlipayService alipayService;
@GetMapping("/pay")
public void pay(HttpServletResponse response) throws Exception {
String qrCodeUrl = alipayService.createQrCode("测试商品", "0.01");
QrCodeUtil.generate(qrCodeUrl, 300, 300, "png", response.getOutputStream());
}
}
2.6 异步通知处理
创建一个Controller处理支付宝的异步通知:
@PostMapping("/notify")
public String handleNotify(HttpServletRequest request) {
Map<String, String> params = request.getParameterMap().entrySet().stream()
.collect(Collectors.toMap(Map.Entry::getKey, e -> e.getValue()[0]));
boolean verifyResult = AlipaySignature.rsaCheckV1(params, env.getProperty("alipay.easy.alipayPublicKey"), "UTF-8", "RSA2");
if (verifyResult) {
String outTradeNo = params.get("out_trade_no");
String totalAmount = params.get("total_amount");
// 更新订单状态等业务逻辑
return "success";
} else {
return "fail";
}
}
3. 测试与调试
-
沙箱环境测试:在支付宝沙箱环境中测试支付流程,确保支付成功和异步通知正常。
-
生产环境部署:将应用部署到生产环境后,将沙箱环境的配置切换为正式环境。
4. 注意事项
-
安全性:确保支付接口的
notify_url
和return_url
安全可靠,防止恶意请求。 -
二维码有效期:在生成二维码时,可以设置二维码的有效时间,过期后重新生成。
-
退款功能:退款操作可以通过调用支付宝的退款接口实现。
通过以上步骤,你可以在Spring Boot项目中成功集成支付宝扫码支付功能,为用户提供便捷的支付体验。