den11100 / yii2-wallet-one-2019
WalletOne服务的组件
1.0.1
2019-08-08 08:14 UTC
Requires
- php: >=5.6.0
- yiisoft/yii2: *
This package is auto-updated.
Last update: 2024-09-08 20:22:00 UTC
README
安装
安装此扩展的首选方式是通过 composer.
要安装,可以运行
$ php composer.phar require den11100/yii2-wallet-one-2019 "^1.0.0"
或添加
"den11100/yii2-wallet-one-2019": "^1.0.0"
到你的 composer.json 文件的 require 部分。
使用方法
配置组件
'walletone'=>[ 'class'=>'den11100\walletone\WalletOne', 'secretKey'=>'....', 'signatureMethod'=>'sha1', 'buttonLabel'=>'....', 'walletOptions'=>[ 'WMI_MERCHANT_ID'=>'...', 'WMI_CURRENCY_ID'=>'...', 'WMI_SUCCESS_URL'=>['site/payment-success'], 'WMI_FAIL_URL'=>['site/payment-fail'], ] ]
secretKey - 这是你的密钥,你可以在你的账户的集成设置页面找到
walletOptions - 这是生成支付表单的参数,你可以设置永久数据
signatureMethod - EDS创建方法,此参数必须与你在账户集成设置页面选择的方法相同(默认 - sha1)
buttonLabel - WalletOneButton的标签
如果你不使用加密方法,你需要将 signatureMethod 和 secretKey 设置为 NULL
显示表单示例
你可以获取字段(添加一些选项),并创建表单
$action = Yii::$app->walletone->apiUrl; $formData = Yii::$app->walletone->getFields([ 'WMI_PAYMENT_AMOUNT'=>'1.00', 'WMI_CURRENCY_ID'=>WalletOne::CurrencyID('UAH'), 'WMI_DESCRIPTION'=>'Top up the account - '.Yii::$app->user->identity->username, 'WMI_PAYMENT_NO'=>Yii::$app->user->id ]); echo Html::beginForm($action); foreach($formData as $key => $value){ echo Html::hiddenInput($key, $value); } echo Html::submitButton('Pay', ['class'=>'btn btn-info']); echo Html::endForm();
或使用简单的表单(按钮)
echo WalletOneButton::widget([ 'walletOptions'=>[ 'WMI_PAYMENT_AMOUNT'=>'1.00', 'WMI_CURRENCY_ID'=>WalletOne::CurrencyID('UAH'), 'WMI_DESCRIPTION'=>'Top up the account - '.Yii::$app->user->identity->username, 'WMI_PAYMENT_NO'=>Yii::$app->user->id ] ]);
成功操作的示例
$post = Yii::$app->request->post(); /** @var WalletOne $walletone */ $walletone = Yii::$app->walletone; try{ if($walletone->checkPayment($post)){ //... save info about payment } }catch (ErrorException $c){ return 'WMI_RESULT=RETRY&WMI_DESCRIPTION='.$c->getMessage(); } return 'WMI_RESULT=OK';