public staticfunction pay($money,$orderNo,$channel)
{
$api_key= Yii::$app->params[‘API_KEY‘];
$app_id= Yii::$app->params[‘PAPP_ID‘];//引入你的签名私钥
$path = dirname(dirname(__FILE__)).‘/components/pingpp/rsa_private_key.pem‘;
\Pingpp\Pingpp::setPrivateKeyPath($path);//$extra用于设置支付渠道所需的额外参数,额外参数多数是可选,请根据需求来决定。详情看参考文档
$extra =[];switch($channel) {case ‘alipay_wap‘:
$extra=array(//success_url 和 cancel_url 在本地测试不要写 localhost ,请写 127.0.0.1。URL 后面不要加自定义参数
‘success_url‘ =>Yii::$app->request->getHostInfo().‘/‘. Yii::$app->params[‘pay_success_url‘],‘cancel_url‘ => Yii::$app->request->getHostInfo().‘/‘.Yii::$app->params[‘pay_cancel_url‘],
);break;case ‘wx_pub‘:
$cookies= Yii::$app->request->cookies;
$wx_code= $cookies->getValue(‘wx_code‘); //下面有將怎麼獲取
$wx_app_id= Yii::$app->params[‘wechat‘][‘wx_app_id‘];
$wx_app_secret= Yii::$app->params[‘wechat‘][‘wx_app_secret‘];
$open_id=WxpubOAuth::getOpenid($wx_app_id, $wx_app_secret, $wx_code);
$extra=array(‘open_id‘ => $open_id//用户在商户微信公众号下的唯一标识,获取方式可参考 pingpp-php/lib/WxpubOAuth.php
);break;}
\Pingpp\Pingpp::setApiKey($api_key);//设置API-KEY
try{//create方法表示发送支付请求到ping++平台,$ch表示请求成功时返回的charge对象(json格式),服务器端如果发起请求成功,此时只需要把charge对象传递给APP客户端,交给客户端处理
$ch =\Pingpp\Charge::create([‘subject‘ => ‘標題‘, //关于这些参数的意义,请参考文档https://www.pingxx.com/api#api-c-new
‘body‘ => ‘內容‘,‘amount‘ =>$money,‘order_no‘ =>$orderNo,‘currency‘ => ‘cny‘, //货币代码
‘extra‘ =>$extra,‘channel‘ =>$channel,‘client_ip‘ => $_SERVER[‘REMOTE_ADDR‘],‘app‘ => [‘id‘ =>$app_id]
]);return$ch;
}catch (\Pingpp\Error\Base $e) { //如果发起支付请求失败,则抛出异常//捕获报错信息
if ($e->getHttpStatus() !=NULL) {
header(‘Status:‘ . $e->getHttpStatus());
echo $e->getHttpBody();
}else{
echo $e->getMessage();
}
}
}