2024-02-28 08:59:47
支付宝支付完成后,支付结果将通过回调通知到您的应用程序(在发起支付时通过NotifyUrl参数指定)。为了确保在开发时接口能够在外网进行访问,我们可以借助内网穿透工具,将本地IP与端口映射成外网可访问地址。
大家好,我是飘渺。在今天的DailyMart项目实战中,我们将探讨如何在领域驱动设计(DDD)开发中集成支付宝的网页支付功能,以及相关的步骤和注意事项。
一、申请阿里沙箱支付
首先,我们需要申请阿里沙箱支付环境,以便于方便地进行支付集成测试。以下是申请沙箱环境的简要流程:
1.访问支付宝沙箱环境,https://open.alipay.com/develop/sandbox/app,注册并登录。
图片
2.设置接口加签方式,并记录对应的公钥和私钥。
图片
二、准备内网穿透工具
支付宝支付完成后,支付结果将通过回调通知到您的应用程序(在发起支付时通过NotifyUrl参数指定)。为了确保在开发时接口能够在外网进行访问,我们可以借助内网穿透工具,将本地IP与端口映射成外网可访问地址。
作为示例,我选择使用花生壳进行内网穿透。你也可以根据需求选择其他工具。
注册并登录https://hsk.oray.com,下载最新客户端。
图片
登录以后配置外网映射,如上所示,我将本地ip+端口9090 (网关服务)映射成了外网访问,红框部分就是对外的访问地址。
三、支付Demo流程演示
完成上述操作后,我们可以借助Alipay提供的SDK,进行支付单元测试。代码位置:
com.jianzh5.dailymart.module.order.infrastructure.alipay.AliPayTest
运行单元测试后可以得到如下的 HTML 脚本.
将这份脚本复制到html文件中就可以直接在浏览器打开,效果如下:
图片
然后从开发平台沙箱账号中拿到账号密码,进行支付。
图片
支付成功后的结果
图片
以上就是集成支付宝进行支付的一个流程,现在我们将支付流程集成到Dailymart中。
四、 DailyMart集成支付功能
4.1 订单支付流程梳理
在集成支付功能之前,我们首先需要梳理订单的创建与支付业务流程。主要包括以下步骤:
1.用户从购物车发起结算后调用后台接口生成订单,订单系统先对库存进行校验,在校验通过后保存商品订单,同时调用库存系统进行库存预扣。同时为了避免用户创建订单后不支付,在创建订单的同时还会向RocketMQ发送一条延时消息,如果用户不支付,30分钟后会删除对应的订单返回相应的库存。(此部分已经在之前的章节中完成)
2.用户确认订单后生成相应的交易流水记录以供后期查账使用,同时调用支付宝网关创建支付订单,系统引导用户跳转到支付宝支付页面。(即前文生成的HTML页面)
3.用户支付成功后,支付宝会通过配置好的NotifyUrl进行回调,在收到支付结果确认以后需要更新订单状态,调用库存服务进行库存扣减。
4.为了防止网络问题导致系统没收到支付宝的回调,还需要一个定时任务定时去检索未支付成功的交易单,调用支付网关确认支付结果并同时更新对应状态。
整体流程图如下所示:
图片
4.2 领域分析
根据订单支付流程,我们需要在订单上下文中创建三个领域对象:
PaymentOrder:支付单,作为聚合对象,用于后期查账。PaymentInfo:支付信息,用于构建支付所需的相关数据,作为值对象。PaymentId:支付单的ID对象,也是值对象。图片
4.3 核心代码示例
1.在订单基础设施层创建属性配置类,用于读取alipay的配置数据
2.创建配置类,用于装载alipay的AlipayClient对象。
3.需要与第三方交互,我们将交互的逻辑放在基础设施层,同时提供接口供上层使用
4.对外提供接口,用于生成alipay支付表单
5.由应用领域层完成支付表单逻辑
6.提供接口供alipay回调,在回调逻辑中完成订单状态和支付订单的更新,同时还需要调用库存服务进行库存扣减,为了实现分布式事务,这里借住RocketMQ的事务消息实现最终一致性。
7.支付单表结构
五、小结
通过以上步骤,我们完成了在DDD开发中集成支付宝网页支付功能的实践。本文涉及的代码都已经上传至Github,感兴趣的可以通过文末方式获取。