一、別的系統安裝添加微信提現功能
第一步:使用composer安裝EasyWeChat
鏈接:https://www.easywechat.com/docs/3.x/installation
第二步:在前面我們已經講過,初始化 SDK 的時候方法就是創建一個
EasyWeChat\Foundation\Application 實例:
use EasyWeChat\Foundation\Application;
$options = [
// ...];
$app = new Application($options);
/**
* 如果想要在Application實例化完成之后, 修改某一個options的值,
* 比如服務商+子商戶支付回調場景, 所有子商戶訂單支付信息都是通過同一個服務商的$option 配置進來的,
* 當oauth在微信端驗證完成之后, 可以通過動態設置merchant_id來區分具體是哪個子商戶
*/$app['config']->set('oauth.callback','wechat/oauthcallback/'. $sub_merchant_id->id);
那么配置的具體選項有哪些,下面是一個完整的列表:
<?php
return [
/**
* 賬號基本信息,請從微信公眾平臺/開放平臺獲取
*/
'app_id' => 'your-app-id', // AppID
'secret' => 'your-app-secret', // AppSecret
'token' => 'your-token', // Token
'aes_key' => '', // EncodingAESKey,安全模式與兼容模式下請一定要填寫?。?!
/**
* OAuth 配置
*
* scopes:公眾平臺(snsapi_userinfo / snsapi_base),開放平臺:snsapi_login
* callback:OAuth授權完成后的回調頁地址
*/
'oauth' => [
'scopes' => ['snsapi_userinfo'],
'callback' => '/examples/oauth_callback.php',
],
/**
* 微信支付
*/
'payment' => [
'merchant_id' => 'your-mch-id',
'key' => 'key-for-signature',
'cert_path' => 'path/to/your/cert.pem', // XXX: 絕對路徑?。。?!
'key_path' => 'path/to/your/key', // XXX: 絕對路徑!?。?!
],
* 更多請參考: http://docs.guzzlephp.org/en/latest/request-options.html
*/
'guzzle' => [
'timeout' => 3.0, // 超時時間(秒)
],];
第三步:使用EasyWeChat完成提現到零錢功能(企業付款到零錢)
你在閱讀本文之前確認你已經仔細閱讀了:微信支付 | 企業付款文檔 。
與其他支付接口一樣,企業支付接口也需要配置如下參數,需要特別注意的是,企業支付相關的全部接口 都需要使用 SSL 證書,因此 cert_path 以及 cert_key 必須正確配置。
<?php
use EasyWeChat\Foundation\Application;
$options = [
'app_id' => 'your-app-id',
// payment
'payment' => [
'merchant_id' => 'your-mch-id',
'key' => 'key-for-signature',
'cert_path' => 'path/to/your/cert.pem',
'key_path' => 'path/to/your/key',
// ...
],];
$app = new Application($options);
$merchantPay = $app->merchant_pay;
企業付款
企業付款使用的余額跟微信支付的收款并非同一賬戶,請注意充值。
<?php
$merchantPayData = [
'partner_trade_no' => str_random(16), //隨機字符串作為訂單號,跟紅包和支付一個概念。
'openid' => $openid, //收款人的openid
'check_name' => 'NO_CHECK', //文檔中有三種校驗實名的方法 NO_CHECK OPTION_CHECK FORCE_CHECK
're_user_name'=>'張三', //OPTION_CHECK FORCE_CHECK 校驗實名的時候必須提交
'amount' => 100, //單位為分
'desc' => '企業付款',
'spbill_create_ip' => '192.168.0.1', //發起交易的IP地址
];
$result = $merchantPay->send($merchantPayData);
查詢付款信息
用于商戶對已發放的企業支付進行查詢企業支付的具體信息。
$partnerTradeNo = "商戶系統內部的訂單號(partner_trade_no)";
$merchantPay->query($partnerTradeNo);
二、知識付費添加微信提現
知識付費系統的微信功能基本類extend\service\WechatService;按照文檔說明我們在WechatService類中添加企業付款的接口,接口名稱為merchantPayService,若是存在就不需要添加;
/**
* 企業付款
* @return \EasyWeChat\Material\Material
*/
public static function merchantPayService()
{
return self::application()->merchant_pay;
}
那么我們所需要的就是調用merchantPayService方法里的send方法,并且傳入我們轉賬的參數即可。
我們需要把功能加到提現審核通過之后執行。admin\model\user\UserExtract;找到這個類中的changeSuccess方法,這個方法是審核通過后的相關操作。
(1)、 先引入WechatService;
use service\WechatService;
(2)、 changeSuccess方法里加下面代碼,并且根據最后的返回判斷企業付款是否成功。
$payData = [
'partner_trade_no' => str_random(16), //隨機字符串作為訂單號,跟紅包和支付一個概念。
'openid' => $openid, //收款人的openid
'check_name' => 'NO_CHECK', //文檔中有三種校驗實名的方法 NO_CHECK OPTION_CHECK FORCE_CHECK
're_user_name'=>'張三', //OPTION_CHECK FORCE_CHECK 校驗實名的時候必須提交
'amount' => 100, //單位為分
'desc' => '企業付款',
'spbill_create_ip' => '192.168.0.1', //發起交易的IP地址
];
$result=WechatService::merchantPayService()->send($payData);