php-cpm / omnipay-wechatpay
Omnipay支付处理库的微信网关
v3.0.6
2018-06-27 03:05 UTC
Requires
- omnipay/common: ~3.0
- php-http/guzzle6-adapter: ^1.1
Requires (Dev)
- omnipay/tests: ~3.0
This package is auto-updated.
Last update: 2024-09-06 09:34:35 UTC
README
本项目基于Omnipay 3.0分支开发,依赖版本较新,也可能会带来不稳定的可能。
增加子商户模式 增加沙箱模式 子商户模式支持小程序的sub_appid和sub_openid传递
Omnipay PHP支付处理库的微信支付驱动
Omnipay 是一个与框架无关、多网关的PHP 5.3+支付处理库。此包实现了Omnipay的微信支付支持。
安装
Omnipay通过 Composer 安装。要安装,只需将其添加到您的 composer.json
文件中
"php-cpm/omnipay-wechatpay": "^3.0",
然后运行composer更新您的依赖项
$ composer update -vvv
基本用法
此包提供了以下网关
- WechatPay (Wechat Common Gateway) 微信支付通用网关
- WechatPay_App (Wechat App Gateway) 微信APP支付网关
- WechatPay_Native (Wechat Native Gateway) 微信原生扫码支付网关
- WechatPay_Js (Wechat Js API/MP Gateway) 微信网页、公众号、小程序支付网关
- WechatPay_Pos (Wechat Micro/POS Gateway) 微信刷卡支付网关
- WechatPay_Mweb (Wechat H5 Gateway) 微信H5支付网关
用法
创建订单 文档
//gateways: WechatPay_App, WechatPay_Native, WechatPay_Js, WechatPay_Pos, WechatPay_Mweb, WechatPay_Lite $gateway = Omnipay::create('WechatPay_App'); $gateway->setAppId($config['app_id']); $gateway->setMchId($config['mch_id']); $gateway->setApiKey($config['api_key']); $order = [ 'body' => 'The test order', 'out_trade_no' => date('YmdHis').mt_rand(1000, 9999), 'total_fee' => 1, //=0.01 'spbill_create_ip' => 'ip_address', 'fee_type' => 'CNY' ]; /** * @var Omnipay\WechatPay\Message\CreateOrderRequest $request * @var Omnipay\WechatPay\Message\CreateOrderResponse $response */ $request = $gateway->purchase($order); $response = $request->send(); //available methods $response->isSuccessful(); $response->getData(); //For debug $response->getAppOrderData(); //For WechatPay_App $response->getJsOrderData(); //For WechatPay_Js $response->getCodeUrl(); //For Native Trade Type
通知 文档
$gateway = Omnipay::create('WechatPay'); $gateway->setAppId($config['app_id']); $gateway->setMchId($config['mch_id']); $gateway->setApiKey($config['api_key']); $response = $gateway->completePurchase([ 'request_params' => file_get_contents('php://input') ])->send(); if ($response->isPaid()) { //pay success var_dump($response->getRequestData()); }else{ //pay fail }
查询订单 文档
$response = $gateway->query([ 'transaction_id' => '1217752501201407033233368018', //The wechat trade no ])->send(); var_dump($response->isSuccessful()); var_dump($response->getData());
关闭订单 文档
$response = $gateway->close([ 'out_trade_no' => '201602011315231245', //The merchant trade no ])->send(); var_dump($response->isSuccessful()); var_dump($response->getData());
退款 文档
$gateway->setCertPath($certPath); $gateway->setKeyPath($keyPath); $response = $gateway->refund([ 'transaction_id' => '1217752501201407033233368018', //The wechat trade no 'out_refund_no' => $outRefundNo, 'total_fee' => 1, //=0.01 'refund_fee' => 1, //=0.01 ])->send(); var_dump($response->isSuccessful()); var_dump($response->getData());
查询退款 文档
$response = $gateway->queryRefund([ 'refund_id' => '1217752501201407033233368018', //Your site trade no, not union tn. ])->send(); var_dump($response->isSuccessful()); var_dump($response->getData());
缩短URL (针对 WechatPay_Native
) 文档
$response = $gateway->shortenUrl([ 'long_url' => $longUrl ])->send(); var_dump($response->isSuccessful()); var_dump($response->getData()); var_dump($response->getShortUrl());
查询OpenId (针对 WechatPay_Pos
) 文档
$response = $gateway->shortenUrl([ 'auth_code' => $authCode ])->send(); var_dump($response->isSuccessful()); var_dump($response->getData()); var_dump($response->getOpenId());
有关一般使用说明,请参阅主要的 Omnipay 仓库。
相关
支持
如果您在使用Omnipay时遇到一般问题,我们建议您在 Stack Overflow 上发布。请确保添加 omnipay 标签,以便易于查找。
如果您想了解发布公告,讨论项目的想法或提出更详细的问题,还有一个您可以订阅的 邮件列表。
如果您认为您已经找到了一个错误,请使用 GitHub问题跟踪器 进行报告,或者更好的是,对库进行分支并提交拉取请求。