phalapi/pay

PhalApi 2.x 扩展类库:第三方支付扩展,含微信支付和支付宝支付

dev-master 2019-04-03 10:45 UTC

This package is not auto-updated.

Last update: 2024-12-20 13:26:44 UTC


README

安装和配置

修改项目下的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();

使用

手动复制PHP示例和入口文件

把 ./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

4. 回调成功说明

异步回调成功后会在日志中生成成功后的信息,失败也会生成

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) {
            //异常失败处理
        }

更多信息,请参考:【微信支付】现金红包开发者文档