修改项目下的composer.json文件,并添加:
"phalapi/pay":"dev-master"
然后执行composer update
。
我们需要在 ./config/app.php 配置文件中追加以下配置:
/**
* 支付相关配置
*/
'Pay' => array(
//异步/同步地址 如果域名指向到Public,那么地址应该是 http://你的域名/pay/
'notify_url' => 'http://www.xxx.com/phalapi/public/pay/',
//支付宝wap端设置
'aliwap' => array(
//收款账号邮箱
'email' => 'admin@admin.com',
//加密key
'key' => 'xxx',
//合作者ID
'partner' => '123456'
),
//微信支付设置
'wechat' => array(
//公众号的唯一标识
'appid' => 'xxx',
//商户号
'mchid' => '123456',
//公众号的appsecret
'appsecret' => 'xxx',
//微信支付Key
'key' => 'xxx'
),
),
支付宝私钥公钥的生成就不多说了,还是自己去看吧! 任意门:https://cshall.alipay.com/enterprise/help_detail.htm?help_id=483847 生成后的文件放至Library/Pay/key目录下,文件名请按照对应的文件名设置
alipay_public_key.pem 为支付宝合作伙伴密钥的支付宝公钥
alipay_rsa_private_key.pem 为自己生成的rsa密钥
在 ./config/di.php文件中,追加注册:
//支付
$di->pay = new \PhalApi\Pay\Lite();
把 ./vendor/phalapi/pay/demo 目录下的代码,复制到到当前项目的src的app内。命令是:
$ cp ./vendor/phalapi/pay/demo/* ./src/app/ -R
同时,需要将支付入口PHP文件也复制到当前项目。把 ./vendor/phalapi/pay/public 目录下的代码,复制到到当前项目的public。命令是:
$ cp ./vendor/phalapi/pay/public/* ./public/ -R
访问链接 http://你的域名/public/pay/项目/?s=App.Pay.Index&type=wechat 参数type为对应的支付引擎的名称。微信为wechat 支付宝wap端为aliwap
如果域名已经设置public目录,就不需要public目录了
如果需要测试微信JSAPI支付,需要在微信浏览器中测试,先将以上的访问链接生成为二维码,然后打开微信扫一扫就可以支付了
//支付宝的异步回调接口
http:://你的域名/public/pay/aliwap/notify.php
//支付宝同步回调接口
http:://你的域名/public/pay/aliwap/return.php
//微信异步回调接口
http:://你的域名/public/pay/wechat/notify.php
支付宝同步回调不知道为什么进行验证时会验证失败,为了节约时间,也没有再修复了,毕竟如果是做接口大部分用不到。如果有同学把问题解决了,请AT我 aer_c@qq.com QQ:7579476 或者添加PhalApi官方交流群:421032344 AT:Summer
异步回调成功后会在日志中生成成功后的信息,失败也会生成
2015-12-18 10:43:36|PAYSUCCESS|Pay Success|{"Type":"aliwap","Method":"notify","Data":{"status":true,"money":"0.01","out_trade_no":"FC180660663677d","trade_no":"2015121800001000630003030428"}}
2015-12-18 10:43:59|PAYSUCCESS|Pay Success|{"Type":"wechat","Method":"notify","Data":{"status":true,"money":0.01,"out_trade_no":"FC180663422083d","trade_no":"1007480911201512182153438132"}}
返回的数据说明
Type 支付方法 aliwap/wechat
Method 回调方式 notify:异步回调 return: 同步回调
Data 订单信息 status: 支付状态 money: 支付的总金额 out_trade_no: 商户订单号 trade_no: 支付宝/微信订单号
###5. 添加新的第三方支付 我相信同学们都看的懂,我都有注释,安装规定的格式添加即可,如果看不懂可以问我,联系方式上面有,就不说了!
PS:我们致力于代码开源,引用老大的一句话 PhalApi是一个PHP轻量级开源接口框架。我们致力于将PhalApi维护成像恒星一样:不断更新,保持生气;为接口负责,为开源负责!让后台接口开发更简单!
###补充微信现金红包 @dogstar 2016-01-21 使用的示例代码如下:
$params = array(
're_openid' => $openId,
'send_name' => '红包发送者名称',
'total_amount' => 100,
'total_num' => 1,
'wishing' => '红包祝福语',
'act_name' => '活动名称',
'remark' => '备注',
);
$payLite = \PhalApi\DI()->get('payLite', 'Pay_Lite');
$payLite->set('wechat');
try {
$sendRs = $payLite->sendredpack($params, $errorMsg);
} catch (Pay_Exception $ex) {
//异常失败处理
}
更多信息,请参考:【微信支付】现金红包开发者文档