支付宝支付-Java基于沙箱环境实现支付宝支付

一、支付宝沙箱环境介绍

沙箱环境是支付宝开放平台为开发者提供的安全低门槛的测试环境,开发者在沙箱环境中调用接口无需具备所需的商业资质,无需绑定和开通产品,同时不会对生产环境中的数据造成任何影响。合理使用沙箱环境,可以让研发流程与商业流程并行,降低联调资损风险,加速项目的交付。更为详细的说明可以看官方文档:小程序文档 - 支付宝文档中心

二、沙箱环境准备

1、 注册入驻支付宝开放平台

登录支付宝开放平台,支付宝开放平台,找到开发接入入驻为开发者。

2 、配置沙箱环境

进入到开发者的控制台,找到最下方的开发者工具推荐 ,点击沙箱

3、 沙箱应用

  • 获取支付参数信息

    打开沙箱应用后,需要拿到3个参数,appId,应用私钥,支付宝公钥,用于对接支付接口使用。

  • 买家和商家账户信息

    在沙箱账号中,可以看到买家和商家的账号信息以及账号余额。当支付时填写买家对应信息,支付成功会看到买家余额减少,卖余额增加。

三、Java实现支付宝支付

支付的整体逻辑是,引入sdk依赖,配置对应的支付参数,调用支付接口支付,等待支付成功后执行回调接口逻辑。 如果希望看到详细说明,也可参看官方文档:小程序文档 - 支付宝文档中心,下面主要是简化业务步骤,记录核心关键步骤。

1 引入SDK的Maven依赖

<!-- https://mvnrepository.com/artifact/com.alipay.sdk/alipay-easysdk -->
<dependency>
    <groupId>com.alipay.sdk</groupId>
    <artifactId>alipay-easysdk</artifactId>
    <version>2.2.2</version>
</dependency>

2 配置支付参数

alipay:
  appId: 9021000136625098
  appPrivateKey: MIIEvQIBADANBgkqhkiG9w0BAQEFAASCBKcwggSjAgEAAoIBAQCnIOaJINZRiyy+H2zYhceXnHA4Gjo64J8tqSvvynBjJgsKaiudE+Kp5uKLSwUPTscEloXRbvKaJtWNowQBRLSUG7QZU67b+RYULM1fgqiBU+NTjKXb5yI1MJNvfIF8831SMtFuM/xBbnPbaZP9NfBssXmG2R4LD9Tgw+Ejtma9HJHU4Lid4Pz9WY/85NXR/Y0Ak/d2vHrdjLyHseXT4ueLd8OhbFA+dBOk87wpMkL8ZGPEjYSgexuwW/avKiSjwBlt/knKK6ba//SESJ4qkpT042YNrGytSdZFLGhanJgi2dIGg5liEBM2yKPcceIf9V2uiDT5wMOjQNEEEx5jcmjnAgMBAAECggEAczcfNtHIbhbAFaGca/huDHrwcfzCv+wyUEwb2gd5SyDi458lyfziQKVIy8nj0McdreohTeCKFuM/HFDw=
  publiceKey: MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAgiFZiGAHcgBfebSnpQunBtRkjvfK2NhPeqHu7Ca17fUcgUOgGwIDAQAB
  notifyUrl: http://h5weixin.w1.luyouxia.net/api/alipay/notify
  gatewayHost: openapi-sandbox.dl.alipaydev.com

3 编写支付属性配置类

@Component
@ConfigurationProperties(prefix = "alipay")
@Data
public class AlipayConfig {
    // 应用Id
    private String appId;
    // 应用私有
    private String appPrivateKey;
    // 支付宝公钥
    private String publiceKey;
    // 回调接口路径
    private String notifyUrl;
    // 支付宝网关地址
    private String gatewayHost;


    @PostConstruct
    public void init(){
        Config config = new Config();
        // 基础配置
        config.protocol = "https";
        config.gatewayHost = this.gatewayHost;// 支付宝网关地址
        config.signType = "RSA2";

        // 业务配置
        config.appId = this.appId;
        config.merchantPrivateKey = this.appPrivateKey;
        config.alipayPublicKey = this.publiceKey;
        config.notifyUrl = this.notifyUrl;

        // 将配置信息, 添加到相应的工厂类
        Factory.setOptions(config);
        System.out.println("支付宝初始化配置完成");

    }
}

4 编写支付接口和支付回调接口

@RestController
@RequestMapping("/api/alipay")
public class PayController {

    /**
     * 订单支付接口, 核心是调用支付宝的 Factory.Payment.Page().pay() 方法
     * @param subject  支付对象信息
     * @param outTradeNo  订单号
     * @param totalAmount 订单金额
     * @param returnUrl   支付成功以后返回的页面地址
     * @return
     */
    @GetMapping
    public String pay(String subject, String outTradeNo, String totalAmount,String returnUrl) throws Exception {
        AlipayTradePagePayResponse  response = Factory.Payment.Page().pay(subject, outTradeNo, totalAmount, returnUrl);
        return response.getBody();
    }


    /**
     * 支付回调接口,如果支付成功,支付宝将会请求此接口,将成功信息返回
     */
    @PostMapping("/notify")
    public String notify(@RequestParam Map parameterMap) throws Exception {
        String tradeStatus = parameterMap.getOrDefault("trade_status","").toString();

        if (tradeStatus.trim().equals("TRADE_SUCCESS")) {
            // 验证请求的有效性
            if (Factory.Payment.Common().verifyNotify(parameterMap)) {
                System.out.println("通过支付宝的验证");
                System.out.println("订单id:" + parameterMap.get("out_trade_no"));
            }else {
                System.out.println("支付验证不通过");
            }
        }
        return "success";
    }

}

四.前端页面

java 复制代码
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
        "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
    <meta charset="UTF-8">
    <title>支付宝支付页面</title>
</head>
<body>
<a href="/api/alipay?subject=杨世聪在线支付&totalAmount=16.0&outTradeNo=1001&returnUrl=http%3A%2F%2Flocalhost%3A8080%2Faliawyok.html%3ForderId%3D1001" >点击支付</a>
</body>
</html>
java 复制代码
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
        "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
    <meta charset="UTF-8">
    <title>支付成功页面</title>
</head>
<body>
支付成功
</body>
</html>

五、内网穿透工具

链接: 点击下载工具

下载路由侠,配置如下

六、验证

1、访问测试

2、跳转到支付界面

3、输入沙箱环境的买家账号和密码支付

4 、支付成功后,支付宝会回调我们提供好的接口路径

相关推荐
yufei-coder18 分钟前
C#基础语法
开发语言·c#·.net
数据龙傲天18 分钟前
1688商品API接口:电商数据自动化的新引擎
java·大数据·sql·mysql
长天一色19 分钟前
【ECMAScript 从入门到进阶教程】第三部分:高级主题(高级函数与范式,元编程,正则表达式,性能优化)
服务器·开发语言·前端·javascript·性能优化·ecmascript
_.Switch30 分钟前
Python机器学习模型的部署与维护:版本管理、监控与更新策略
开发语言·人工智能·python·算法·机器学习
醉颜凉33 分钟前
银河麒麟桌面操作系统修改默认Shell为Bash
运维·服务器·开发语言·bash·kylin·国产化·银河麒麟操作系统
NiNg_1_23439 分钟前
Vue3 Pinia持久化存储
开发语言·javascript·ecmascript
带带老表学爬虫1 小时前
java数据类型转换和注释
java·开发语言
qianbo_insist1 小时前
simple c++ 无锁队列
开发语言·c++
千里码aicood1 小时前
【2025】springboot教学评价管理系统(源码+文档+调试+答疑)
java·spring boot·后端·教学管理系统
BigYe程普1 小时前
我开发了一个出海全栈SaaS工具,还写了一套全栈开发教程
开发语言·前端·chrome·chatgpt·reactjs·个人开发