怎么自己封装支付模块封装?

标准库编写支持.NET Framework以及.NET Core。目前已提供Abp模块封装的封装支持开箱即用。

标准库编写支持.NET Framework以及.NET Core。目前已提供Abp模块封装的封装支持开箱即用。目前支持以下支付方式和功能:

  • 支持日志函数注入(不依赖支付库)

  • 支持支付配置函数注入以便于支持自定义配置获取逻辑,以应用于不同的场景(比如从配置文件、用户设置获取配置或者多租户支持)

  • 针对ABP提供模块封装封装,添加模块封装依赖即可立即使用主要包括:

    • 交易日志封装,自动记錄客户端信息以及自动异常处理和记录

    • 仅需编写一次回调逻辑即可支持多个支付渠道

    • 业务参数支持更大长度(500)

如果使用Abp相关模块封装,则使用起来比较简单具体您可以参考相关单元测试的编写。主要有以下步骤:

  1. 引用对应的Abp支付的Nuget包 如果仅需某个支付仅需引用该支付的包。下面以通联支付为例我们需要在工程中引用此包:

  1. 在DbContext中添加名为“TransactionLogs”的DbSet 整个支付过程中(无论是支付成功还是出现异常),均會记录交易日志交易日志会记录交易过程中的一些信息,比如客户端信息、交易参数、自定义参数以及异常信息因此我们需要针对EF添加对TransactionLog的支持。需要在DbContext中添加的完整代码如下所示:

  1. 注册回调逻辑 我们需要实现“IPaymentCallbackAction”接口来编写自定义的回调逻辑如以下示例所示:

我们鈳以将回调逻辑写在一个公共的程序集,然后使用以下代码进行注册:

//注册自定义支付回调逻辑

通过容器获得IPayAppService然后调用Pay方法即可。也可鉯自行封装:

  • 统一支付(无论支付宝还是微信各种端的支付均可统一)

  • 自动记录交易日志以及进行相关逻辑处理

  • 自定义数据依赖交易日誌进行存储,而不依赖支付渠道因此支持无业务参数的支付渠道,也支持存储更多自定义数据

请参考Abp相关模块封装的封装或者历史代码

关注“麦扣聊技术”订阅号免费获取:

我要回帖

更多关于 模块封装 的文章

 

随机推荐