Download the PHP package bobcoders9/cashier without Composer
On this page you can find all versions of the php package bobcoders9/cashier. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Informations about the package cashier
cashier
支持网关
名称 | 网关 | 支持动作 | 支持回调 | 备注 |
---|---|---|---|---|
alipay_app | 支付宝 APP 支付 | 支付/支付查询/退款 | 支付 | |
alipay_qr | 支付宝扫码支付 | 支付/支付查询/退款 | 支付 | |
alipay_wap | 支付宝手机网站支付 | 支付/支付查询/退款 | 支付 | |
alipay_web | 支付宝 PC 网站支付 | 支付/支付查询/退款 | 支付 | |
wechat_app | 微信 APP 支付 | 支付/支付查询/退款/退款查询 | 支付通知/退款通知 | |
wechat_h5 | 微信 H5 支付 | 支付/支付查询/退款/退款查询 | 支付通知/退款通知 | 内置抓取付款链接功能 |
wechat_mina | 微信小程序支付 | 支付/支付查询/退款/退款查询 | 支付通知/退款通知 | |
wechat_official | 微信公众号支付 | 支付/支付查询/退款/退款查询 | 支付通知/退款通知 | |
wechat_qr | 微信扫码支付 | 支付/支付查询/退款/退款查询 | 支付通知/退款通知 | |
union_web | 银联网页支付 | 支付/支付查询 | 支付通知 | 较旧版本 |
union_app | 银联网页支付 | 支付 | 支付通知 | 较旧版本 |
paypal_express_checkout | PayPal 快速结账 | 支付/支付查询 | 支付通知 | 不稳定 |
wechatoversea_official | 微信跨境公众号支付 | 支付/支付查询/退款 | 支付 |
介绍
在对接第三方支付中, 尤其是需要对接多个第三方支付时, 需要阅读第三方文档然后花费大量时间拼装和调试参数, 例如调用第三方下单创建支付, 如果需要同时接入微信跟支付宝支付, 那么就需要收集文档, 可想而知是非常麻烦的(其实还好.. hhh..).
这个组件提供的把与第三方通信分为三部分:
- request, 请求, 主动调用第三方
- response, 响应, 主动调用第三方获得的响应
- notification, 通知, 第三方的各类通知
而每部分又部分为不同的动作, 每个动作绑定一个固定的表单 (Form), 每个表单的内容是固定的.
例如主动调用第三方下单创建支付 (ChargeRequest), 他使用的表单是 ChargeRequestForm
. 填写好表单后, 传入组件, 即可由组件加工好参数并调用第三方支付.
这样就能做到, 只需要了解组件的表单内容, 就可以接入多个第三方支付, 一劳永逸 (不存在的 hhh).
使用
这里以支付宝 PC 网站支付为例, 如果需要使用其他的支付网关, 只需要修改实例化 Cashier
时传入的 $gateway
即可.
注意, 组件使用的基本货币单位是 分.
创建付款
查询支付
接收通知
退款
表单及字段说明
ChargeRequestForm
字段名 | 是否必须 | 字段说明 | 备注 |
---|---|---|---|
order_id | 是 | 订单号 | |
subject | 是 | 订单标题 | |
amount | 是 | 订单金额 | 注意部分支付渠道有金额上线限制 |
currency | 是 | 订单货币 | 注意支付渠道支付 |
description | 是 | 订单简述 | 支付渠道会有不同的长度限制 |
user_ip | 否 | 用户IP | |
return_url | 否 | 回调地址 | web类型的支付渠道必须填 |
show_url | 否 | 展示地址 | |
body | 否 | 订单详细说明 | 这个参数我应该删掉 |
expired_at | 否 | 过期时间 | unix 时间戳 |
created_at | 否 | 创建时间 | unix 时间戳, 想不到吧, 连这个鬼都要?? |
其他依旧待补充...
FAQ
Q: 相比其他的 sdk 优点在哪 ?
A: 无论标榜多优雅多好用的 sdk, 大多都是要求你按照第三方的参数名传入参数, 那就免不了要看文档, 免不了在代码里要做很多处理. 我想要的是, 从数据库里取出订单后, 做一遍处理就能解决接入多种支付.
Q: 是不是就完全不必看第三方支付的文档了 ?
A: 并不是, 我建议还是需要看, 并且组件中某些支付 (例如微信公众号) 是需要传入一些特殊参数的. 组件只是帮你解决烦心的调用问题.
License
MIT