ThinkAdmin V6 官方文档

💳 ThinkPlugsPayment

Latest Stable Version Latest Unstable Version Total Downloads Monthly Downloads Daily Downloads PHP Version License

ThinkPlugsPaymentThinkAdmin 的多端支付插件,本插件属于会员尊享插件,未经授权不得用于商业用途。

🚀 主要功能

  • 多端支付支持: 支持微信支付、支付宝支付等多种支付方式
  • 混合支付: 同一订单支持多种支付方式组合
  • 账户管理: 余额支付、积分抵扣功能
  • 支付监控: 实时支付状态监控和回调处理
  • 数据统计: 支付数据统计和分析
  • 安全防护: 支付安全验证和风险控制

💰 支付类型

支付类型主要涵盖线上支付和抵扣支付两大类。

抵扣支付

  • 账户余额支付: 使用账户余额进行支付
  • 账户积分抵扣: 使用积分抵扣部分或全部金额

线上支付

  • 微信支付: 公众号支付、小程序支付、APP支付、H5支付
  • 支付宝支付: 网页支付、手机支付、APP支付、扫码支付
  • 凭证单据支付: 银行转账、现金支付等凭证支付

⚙️ 支付配置

支付优先级

默认情况下,账户余额支付和账户积分抵扣均得到支持,但业务系统可根据需求控制是否向用户开放。在支付优先级方面,积分优先于余额,余额则优先于其他支付方式

若您希望完全关闭积分抵扣或余额支付功能,只需在支付配置中取消对应的支付方式选项即可。

混合支付支持

当前,同一业务订单支持混合支付模式,业务系统需传入订单需支付的总金额及此次支付金额。支付完成情况将根据已完成的支付总额来判断,并触发全局支付事件。您可以在任意初始化文件中监听支付事件,以便实时刷新订单状态。

退款支持

待办事项:未来子支付单将支持独立的退款操作。目前,积分抵扣、余额支付、凭证支付以及微信支付退款操作已得到支持。敬请期待更多更新与优化。

加入我们

我们的代码仓库已移至 Github,而 Gitee 则仅作为国内镜像仓库,方便广大开发者获取和使用。若想提交 PRISSUE 请在 ThinkAdminDeveloper 仓库进行操作,如果在其他仓库操作或提交问题将无法处理!。

开放接口

接口文档: https://thinkadmin.apifox.cn

支付事件

可以在相应插件的服务内注册事件回调函数,如:代码案例

  • PluginAccountBind 注册用户绑定事件,回调参数 function (array $data);
  • PluginPaymentAudit 注册支付审核事件,回调参数 function (PluginPaymentRecord $payment);
  • PluginPaymentRefuse 注册支付拒审事件,回调参数 function (PluginPaymentRecord $payment);
  • PluginPaymentSuccess 注册支付完成事件,回调参数 function (PluginPaymentRecord $payment);
  • PluginPaymentCancel 注册支付取消事件,回调参数 function (PluginPaymentRecord $payment);
  • PluginPaymentConfirm 注册订单确认事件,回调参数 function (array $data);

标准安装

**安装前建议尝试更新所有组件**
composer update --optimize-autoloader

**安装稳定版本 ( 插件仅支持在 ThinkAdmin v6.1 中使用 )**
composer require zoujingli/think-plugs-payment --optimize-autoloader

**安装测试版本( 插件仅支持在 ThinkAdmin v6.1 中使用 )**
composer require zoujingli/think-plugs-payment dev-master --optimize-autoloader

定制安装

  • 复制插件 ThinkPlugsPayment 所有源代码到 plugin/think-plugs-payment 目录。
  • 修改插件 composer.json 文件追加 version 配置项,插件 ThinkPlugsPayment 的完整配置如下:
{
 "type": "think-admin-plugin",
 "name": "zoujingli/think-plugs-payment",
 "version": "1.0.0",
 "homepage": "https://thinkadmin.top",
 "description": "Payment Plugin for ThinkAdmin",
 "authors": [
 {
 "name": "Anyon",
 "email": "zoujingli@qq.com"
 }
 ],
 "require": {
 "php": ">7.1",
 "ext-json": "*",
 "zoujingli/think-library": "^6.1|@dev",
 "zoujingli/think-plugs-account": "^1.0|@dev"
 },
 "require-dev": {
 "phpunit/phpunit": "*"
 },
 "autoload": {
 "psr-4": {
 "plugin\\payment\\": "src"
 }
 },
 "autoload-dev": {
 "psr-4": {
 "think\\admin\\tests\\": "tests/"
 }
 },
 "extra": {
 "think": {
 "services": [
 "plugin\\payment\\Service"
 ]
 },
 "plugin": {
 "copy": {
 "stc/database": "database/migrations"
 }
 },
 "config": {
 "type": "plugin",
 "name": "系统支付管理",
 "document": "https://thinkadmin.top/plugin/think-plugs-payment.html",
 "license": [
 "VIP"
 ]
 }
 }
}
  • 修改项目根 composer.json 配置,增加 ThinkPlugsPayment 插件本地化路径配置,完整配置如下:
{
 "type": "project",
 "name": "zoujingli/thinkadmin",
 "version": "1.0.0",
 "license": "MIT",
 "homepage": "https://thinkadmin.top",
 "description": "Application Development Framework",
 "keywords": [
 "ThinkAdmin",
 "ThinkLibrary",
 "WeChatDeveloper"
 ],
 "authors": [
 {
 "name": "Anyon",
 "email": "zoujingli@qq.com"
 }
 ],
 "require": {
 "php": ">7.1",
 "ext-gd": "*",
 "ext-json": "*",
 "ext-openssl": "*",
 "zoujingli/think-plugs-account": "^1.0",
 "zoujingli/think-plugs-payment": "^1.0"
 },
 "repositories": [
 {
 "type": "path",
 "url": "plugin/think-plugs-payment"
 }
 ],
 "config": {
 "sort-packages": true,
 "allow-plugins": {
 "zoujingli/think-install": true
 }
 }
}
  • 在项目根目录终端执行 composer update 完成安装。

卸载插件

**注意,插件卸载不会删除数据表,需要手动删除**
composer remove zoujingli/think-plugs-payment

插件数据

本插件涉及数据表有:

  • 插件-支付-地址:plugin_payment_address
  • 插件-支付-余额:plugin_payment_balance
  • 插件-支付-积分:plugin_payment_integral
  • 插件-支付-配置:plugin_payment_config
  • 插件-支付-行为:plugin_payment_record

版权说明

ThinkPlugsPaymentThinkAdmin 会员插件。

未获得此插件授权时仅供参考学习不可商用,了解商用授权请阅读 《会员授权》

版权所有 Copyright © 2014-2024 by ThinkAdmin (https://thinkadmin.top) All rights reserved。

最近更新:
Contributors: 邹景立, Anyon

AltStyle によって変換されたページ (->オリジナル) /