mirror of
https://gitee.com/dromara/dax-pay.git
synced 2025-09-08 21:47:36 +00:00
176 lines
7.7 KiB
Markdown
176 lines
7.7 KiB
Markdown
<p align="center">
|
||
<img src="_doc/images/dax-pay.svg" width="45%">
|
||
</p>
|
||
|
||
<p align="center">
|
||
<img src="https://img.shields.io/github/stars/dromara/dax-pay?style=flat&label=Github">
|
||
<img src='https://gitee.com/bootx/dax-pay/badge/star.svg?theme=dark' alt='star'/>
|
||
<img src="https://img.shields.io/badge/Dax%20Pay-3.0.0-success.svg" alt="Build Status"/>
|
||
<img src="https://img.shields.io/badge/Author-Daxpay-orange.svg" alt="Build Status"/>
|
||
<img src="https://img.shields.io/badge/Spring%20Boot-3.3.4-blue.svg" alt="Downloads"/>
|
||
<img src="https://img.shields.io/badge/license-Apache%20License%202.0-green.svg"/>
|
||
</p>
|
||
|
||
# Dromara Dax-Pay(开源支付系统-单商户版)
|
||
> **`multi-xxx` 相关分支为多商户版本, `single-xxx` 相关分支为单商户版本**, **目前都在最后阶段的开发中, 尽请期待**
|
||
|
||
## ❗使用须知
|
||
|
||
`DaxPay`是一款基于`Apache License 2.0`协议分发的开源软件,受中华人民共和国相关法律法规的保护和限制,可以在符合[《用户授权使用协议》](用户授权使用协议.txt)和
|
||
[《Apache License 2.0》](LICENSE)开源协议情况下进行免费使用、学习和交流。**在使用前请阅读上述协议,如果不同意请勿进行使用。**
|
||
|
||
## 🍈项目介绍
|
||
|
||
> DaxPay是一套开源支付网关系统,已经对接支付宝、微信支付、云闪付相关的接口。可以独立部署,提供接口供业务系统进行调用,不对原有系统产生影响。
|
||
>
|
||
|
||
## 🧭 特色功能
|
||
- 封装各类支付通道的接口为统一的接口,方便业务系统进行调用,简化对接多种支付方式的复杂度
|
||
- 已对接`微信支付`、`支付宝`和`云闪付`相关的接口,并以扩展包的方式支持更多类型的通道
|
||
- 支持支付、退款、对账、分账等支付相关的能力
|
||
- 提供`HTTP`方式接口调用能力,和`Java`版本的`SDK`,方便业务系统进行对接
|
||
- 接口请求和响应数据支持启用签名机制,保证交易安全可靠
|
||
- 提供管理端,方便运营人员进行管理和操作,不需要懂IT技术也可以轻松使用
|
||
|
||
## 📃 文档和源码地址
|
||
### 文档地址
|
||
在 [DaxPay文档站](https://doc.daxpay.cn/) 下的支付网关(DaxPay)模块下可以进行查阅相关文档,具体链接地址如下:
|
||
[快速指南](https://doc.daxpay.cn/single/guides/overview/项目介绍.html)、
|
||
[支付对接](https://doc.daxpay.cn/single/gateway/overview/接口清单.html)、
|
||
[操作手册](https://doc.daxpay.cn/single/admin/config/平台配置.html)
|
||
|
||
### 项目地址
|
||
|
||
| 项目 | GITEE | GITHUB | GITCODE |
|
||
|---------|---------------------------------------------|-------------------------------------------------|------------------------------------------------|
|
||
| 后端地址 | [GITEE](https://gitee.com/dromara/dax-pay) | [GITHUB](https://github.com/dromara/dax-pay) | [GITCODE](https://gitcode.com/dromara/dax-pay) |
|
||
| Web前端地址 | [GITEE](https://gitee.com/bootx/dax-pay-ui) | [GITHUB](https://github.com/xxm1995/dax-pay-ui) | |
|
||
| H5前端地址 | [GITEE](https://gitee.com/bootx/dax-pay-h5) | [GITHUB](https://github.com/xxm1995/dax-pay-h5) | |
|
||
|
||
|
||
## 🏬 系统演示
|
||
### 管理平台:
|
||
> 注:演示账号部分功能修改删除权限未开放。
|
||
|
||
地址:https://single.web.daxpay.cn
|
||
|
||
账号:daxpay
|
||
|
||
密码:123456
|
||
|
||
## 🥞 核心技术栈
|
||
| 名称 | 描述 | 版本要求 |
|
||
|-------------|----------|-----------------------|
|
||
| Jdk | Java环境 | 21+ |
|
||
| Spring Boot | 开发框架 | 3.3.x |
|
||
| Redis | 分布式缓存 | 5.x版本及以上 |
|
||
| Vue | 前端框架 | 3.x |
|
||
|
||
## 🛠️ 业务系统接入
|
||
> 业务系统想接入支付网关的话,不需要集成到业务系统里,只需要单独部署一份支付系统,然后业务系统通过接口调用即可拥有对应的支付能力,
|
||
不会对原业务系统的架构产生影响。如果是Java项目,可以使用SDK简化接入流程, 其他语言可以参照中的说明使用HTTP接口方式接入。
|
||
|
||
### Java客户端SDK
|
||
> SDK版本号与支付网关的版本保持一致,如果需要使用,请在pom.xml中添加如下依赖。SDK使用方式参考[SDK使用说明](https://doc.daxpay.cn/single/gateway/overview/SDK使用说明.html)。
|
||
|
||
```xml
|
||
<!-- 支付SDK -->
|
||
<dependency>
|
||
<groupId>org.dromara.daxpay</groupId>
|
||
<artifactId>daxpay-single-sdk</artifactId>
|
||
<version>${latest.version}</version>
|
||
</dependency>
|
||
```
|
||
### SDK调用示例
|
||
> 此处以支付接口为例,演示业务系统如何调用支付网关进行支付,其他接口的调用方式类似,具体请参考[支付对接](https://doc.daxpay.cn/single/gateway/overview/接口清单.html)。
|
||
|
||
```java
|
||
/**
|
||
* 统一支付接口
|
||
* @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收银台演示
|
||

|
||
### 支付通道配置
|
||

|
||
## 🛣️ 路线图
|
||
|
||
[**当前开发进度和任务池**](/_doc/Task.md)
|
||
|
||
[**历史更新记录**](/_doc/Changelog.md)
|
||
|
||
## 🥪 关于我们
|
||
|
||
扫码加入QQ交流群
|
||
|
||
交流二群: 598644350
|
||
<p>
|
||
<img src="https://cdn.jsdmirror.com/gh/xxm1995/picx-images-hosting@master/connect/微信图片_20240513180310.2yy68aykip.webp" width = "330" height = "500"/>
|
||
</p>
|
||
|
||
扫码加入钉钉交流群: [加群连接](https://qr.dingtalk.com/action/joingroup?code=v1,k1,AzkcWLa8J/OHXi+nTWwNRc68IAJ0ckWXEEIvrJofq2A=&_dt_no_comment=1&origin=11)
|
||
<p>
|
||
<img src="https://cdn.jsdmirror.com/gh/xxm1995/picx-images-hosting@master/connect/png-(1).7egk526qnp.webp" width = "400" height = "400"/>
|
||
</p>
|
||
|
||
微信扫码加小助手拉群: sdcit2020
|
||
<p>
|
||
<img alt="微信图片_20240226144703" height="480" src="https://cdn.jsdmirror.com/gh/xxm1995/picx-images-hosting@master/connect/微信图片_20240412152722.231nkeje2o.webp" width="330"/>
|
||
</p>
|
||
|
||
## Star History
|
||
|
||
[](https://starchart.cc/dromara/dax-pay)
|
||
|
||
|
||
## 🍻 鸣谢
|
||
感谢 JetBrains 提供的免费开源 License:
|
||
|
||
[](https://www.jetbrains.com/?from=bootx)
|
||
|
||
感谢其他提供灵感和思路的开源项目
|
||
|
||
[部分参考的开源项目和开源许可列表](./_license/LICENSE.md)
|
||
|
||
|
||
## 🍷License
|
||
|
||
Apache License Version 2.0
|