基于 Ping++ 官方的 SDK 进行了简单的封装,用于 Yii2 框架。
The preferred way to install this extension is through composer.
Either run
composer require --prefer-dist idarex/pingpp-yii2
or add
"idarex/pingpp-yii2": "dev-master"
to the require
section of your composer.json.
To use this extension, simply add the following code in your application configuration:
return [
//....
'components' => [
'pingpp' => [
'class' => '\idarex\pingppyii2\PingppComponent',
'apiKey' => '<YOUR_API_KEY>',
'appId' => '<YOUR_APP_ID>',
// !important 微信公众号付款须设置 wxAppId 和 wxAppSecret
// 'wxAppId' => '<YOUR_WX_APP_ID>',
// 'wxAppSecret' => '<YOUR_WX_APP_SECRET>',
// 'privateKeyPath' => '<YOUR_RSA_PRIVATE_KEY_PATH>', // 设置这个了就不用设置 privateKey 了
// 'privateKey' => '<YOUR_RSA_PRIVATE_KEY_CONTENT>',
],
],
];
use Yii;
use yii\web\ServerErrorHttpException;
use idarex\pingppyii2\Channel;
use idarex\pingppyii2\ChargeForm;
$chargeForm = new ChargeForm();
$chargeForm->order_no = '123456789';
$chargeForm->amount = '100';
/**
* @see Channel
*/
$chargeForm->channel = Channel::WX;
$chargeForm->currency = 'cny';
$chargeForm->client_ip = Yii::$app->getRequest()->userIP;
$chargeForm->subject = 'Your Subject';
$chargeForm->body = 'Your body';
if ($chargeForm->create()) {
return $chargeForm->getCharge(true);
} elseif ($chargeForm->hasErrors()) {
var_dump($chargeForm->getErrors());
} else {
throw new ServerErrorHttpException();
}
\Yii::$app->pingpp->refunds($chId, $amount, $description);
查询单笔交易
\Yii::$app->pingpp->retrieve($chId);
查询交易列表
$params = ['limit' => 1,];
\Yii::$app->pingpp->chargeList($params);
查询单笔退款
\Yii::$app->pingpp->refundRetrieve($chId, $refundId);
查询退款列表
$params = ['limit' => 1];
\Yii::$app->pingpp->refundRetrieveList($chId, $params);
use yii\web\ServerErrorHttpException;
use idarex\pingppyii2\RedEnvelopeForm;
$postData = [
'order_no' => '2022222222016',
'amount' => 200,
'channel' => 'wx',
'currency' => 'cny',
'subject' => 'idarex pingpp-yii2 tests',
'body' => 'idarex pingpp-yii2 tests body',
'nickname' => 'bob',
'sendName' => 'bob',
'recipient' => 'bobchengbin',
];
$form = new RedEnvelopeForm();
$form->load($postData, '');
if ($form->create()) {
return $form->getData(true);
} elseif ($form->hasErrors()) {
var_dump($form->getErrors());
} else {
throw new ServerErrorHttpException();
}
\Yii::$app->pingpp->redEnvelopeRetrieve($redId);
$params = ['limit' => 1,];
\Yii::$app->pingpp->redEnvelopeList($params);
如果使用微信 JS-SDK 来调起支付,需要在创建 charge 后,获取签名(signature),传给 HTML5 SDK。
- 创建Charge
- 获取 Wechat 支付 Signature:
$wechatSignature = $chargeForm->getWechatSignature(); $charge = $chargeForm->getCharge(true); }```
- 在 HTML5 SDK 里调用
pingpp.createPayment(charge, callback, signature, false);
\Yii::$app->pingpp->eventRetrieve($eventId);
$params = ['type' => 'charge.succeeded'];
\Yii::$app->pingpp->eventList($params);
use yii\web\ServerErrorHttpException;
use idarex\pingppyii2\TransferForm;
$postData = [
'amount' => 100,
'order_no' => '20160419',
'currency' => 'cny',
'channel' => 'wx_pub',
'type' => 'b2c',
'recipient' => 'o9zpMs9jIaLynQY9N6yxcZ',
'description' => 'testing',
'user_name' => 'User Name',
'force_check' => true,
];
$form = new TransferForm();
$form->load($postData, '');
if ($form->create()) {
return $form->getData(true);
} elseif ($form->hasErrors()) {
var_dump($form->getErrors());
} else {
throw new ServerErrorHttpException();
}
查询 Transfer 列表
$params = ['limit' => 1];
\Yii::$app->pingpp->transferList($params);
查询指定 Transfer
\Yii::$app->pingpp->transferRetrieve($transferId);
Modify your controler, add or change methode actions()
/**
* @inheritdoc
*/
public function beforeAction($action)
{
if ($action->id == 'pingpp-hooks') {
// 当用户完成交易后 Ping++ 会以 POST 方式把数据发送到你的 hook 地址
// 所以这时候需要临时关闭掉 Yii 的 CSRF 验证
Yii::$app->controller->enableCsrfValidation = false;
}
return parent::beforeAction($action);
}
public function actions()
{
return [
// ...
'pingpp-hooks' => [
'class' => '\idarex\pingppyii2\HooksAction',
'pingppHooksComponentClass' => 'common\components\PingppHooks',
'publicKeyPath' => '@common/config/pingpp_rsa_public_key.pem',
],
];
}
#file: common/components/PingppHooks.php
- 使用
$this->event
来访问 Ping++ 提交过来的数据 - 用
Yii::$app->getResponse()->data = '';
来给返回值赋值。 - 方法最后调用
Yii::$app->end();
来结束请求。
<?php
namespace common\components;
use idarex\pingppyii2\Hooks;
use idarex\pingppyii2\HooksInterface;
use Yii;
class PingppHooks extends Hooks implements HooksInterface
{
/**
* @inheritdoc
*/
public function onAvailableDailySummary()
{
Yii::$app->end();
}
/**
* @inheritdoc
*/
public function onAvailableWeeklySummary()
{
Yii::$app->end();
}
/**
* @inheritdoc
*/
public function onAvailableMonthlySummary()
{
Yii::$app->end();
}
/**
* @inheritdoc
*/
public function onSucceededCharge()
{
$orderId = $this->event->data->object->order_no;
Yii::$app->getResponse()->data = 'finished job';
Yii::$app->end();
}
/**
* @inheritdoc
*/
public function onSucceededRefund()
{
Yii::$app->end();
}
/**
* @inheritdoc
*/
public function onSucceededTransfer()
{
Yii::$app->end();
}
/**
* @inheritdoc
*/
public function onSentRedEnvelope()
{
Yii::$app->end();
}
/**
* @inheritdoc
*/
public function onReceivedRedEnvelope()
{
Yii::$app->end();
}
}
- 给配置的组件加 IDE 自动补全 IDE autocompletion for custom components
- 手动标记一个测试环境的订单为已支付,使用
GET
请求https://api.pingxx.com/notify/charges/CHARGE_ID?livemode=false
- 调用组件的相应方法后,会有对该接口返回值的对象属性自动补全功能