一款免費開源的支付系統
項目介紹
DaxPay是一套開源支付網關系統,已經對接支付寶、微信支付、云閃付相關的接口。可以獨立部署,提供接口供業務系統進行調用,不對原有系統產生影響。
特色功能
- 封裝各類支付通道的接口為統一的接口,方便業務系統進行調用,簡化對接多種支付方式的復雜度
- 已對接微信支付、支付寶和云閃付相關的接口,后續版本將支持V3版本的接口
- 支持支付、退款、對賬、分賬等支付相關的能力
- 提供HTTP方式接口調用能力,和Java版本的SDK,方便業務系統進行對接
- 接口請求和響應數據支持啟用簽名機制,保證交易安全可靠
- 提供管理平臺,方便運營人員進行管理和操作,不需要懂IT技術也可以輕松使用
- 提供聚合支付、電腦收銀臺和手機收銀臺的演示模塊,供開發者參考其實現支付功能的邏輯
核心技術棧
業務系統接入
業務系統想接入支付網關的話,不需要集成到業務系統里,只需要單獨部署一份支付系統,然后業務系統通過接口調用即可擁有對應的支付能力, 不會對原業務系統的架構產生影響。如果是Java項目,可以使用SDK簡化接入流程, 其他語言可以參照中的說明使用HTTP接口方式接入。
1.Java客戶端SDK
SDK版本號與支付網關的版本保持一致,如果需要使用,請在pom.xml中添加如下依賴。
<!-- 支付SDK -->
<dependency>
<groupId>cn.daxpay.single</groupId>
<artifactId>daxpay-single-sdk</artifactId>
<version>${latest.version}</version>
</dependency>
此處以支付接口為例,演示業務系統如何調用支付網關進行支付,其他接口的調用方式類似,具體請參考支付對接。
/**
* 統一支付接口
* @author xxm
* @since 2024/2/5
*/
public class PayOrderTest {
@Before
public void init() {
// 初始化支付配置
DaxPayConfig config = DaxPayConfig.builder()
.serviceUrl("http://127.0.0.1:9000")
.signSecret("123456")
.signType(SignTypeEnum.HMAC_SHA256)
.build();
DaxPayKit.initConfig(config);
}
/**
* 支付
*/
@Test
public void pay() {
PayParam param = new PayParam();
param.setClientIp("127.0.0.1");
param.setBizOrderNo("P0004");
param.setTitle("測試接口支付");
param.setChannel(PayChannelEnum.ALI.getCode());
DaxPayResult<PayModel> execute = DaxPayKit.execute(param);
System.out.println(JSONUtil.toJsonStr(execute));
}
}
系統截圖
收銀臺演示:
駕駛艙:
H5收銀臺演示:
支付通道配置:
開源地址:https://gitee.com/dromara/dax-pay