【Laravel 分账-微信支付API v3 项目实战】

本文详细描述了如何在服务端实现微信支付APIv3的分账功能,包括代码封装、调用过程以及应用场景,如商家与平台的收入分账和分销员分佣。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、项目背景

初衷

前面文章介绍了服务端和小程序端实现微信支付API v3的整个流程,现在介绍下微信支付API v3-分账功能的实现。

二、代码实现

首先,我们可以自行参考下: 微信支付官方API文档-分账
上代码:

// 微信支付分账方法封装
public function profitSendV3($transaction_id,$merchant=[]){
   $out_order_no = mt_rand(100000,999999).time().mt_rand(100,999);
   //是否解冻剩余未分资金,暂时请求分账即解冻,后续可看需求调整
   $unfreeze_unsplit = true;
   //组合分账数据
   list($receivers,$moneyUseTotal) = $this->getReceivers($order,$product);
   $newPara["receivers"] = json_encode($receivers);
   $newPara["appid"] = $this->config['app_id'];
   // 省略部分取数据代码
   // ...
   try {
       $json = [
           'out_order_no'      => $out_order_no,
           'appid'             => $newPara["appid"],
           'transaction_id'    => $transaction_id,
           'receivers'         => $receivers,
           'unfreeze_unsplit'  => $unfreeze_unsplit,
       ];
       $resp = $this->instance
           ->chain('v3/profitsharing/orders')
           ->post(
               ['headers'=> [ //这里加这个字段
                   'Wechatpay-Serial'=>$this->platformCertificateSerial  // 这里加上Wechatpay-Serial
               ],
                   'json' => $json
               ]);

       $result = json_decode($resp->getBody(), true);
       ProcessReceivers::dispatch($this->mer_id,$transaction_id,$out_order_no)->delay(now()->addSecond(3));
       return 'SUCCESS';
   } catch (\Exception $e) {
       // 进行错误处理
       $this->err_msg = $e->getMessage();
       if ($e instanceof \GuzzleHttp\Exception\RequestException && $e->hasResponse()) {
           $r = $e->getResponse();
           $result = $r->getBody();
           $result = json_decode($result,true);
           $this->err_code = $result['code'];
           $this->err_msg = $result['message'];
       }
       return false;
   }
}

小结

微信支付-分账的应用场景还是很多的,比如普通商家的收入分账给平台、分销员来进行分佣操作。

### 微信支付分账功能在Node.js中的实现 对于希望集成微信支付分账功能的应用程序而言,在Node.js环境中可以利用`wechatpay-node-v3`库来简化开发流程[^2]。此库提供了对微信支付v3 API的支持,包括但不限于分账操作。 #### 使用 `wechatpay-node-v3` 库进行分账处理 为了完成分账过程,通常需要先创建一个订单并成功交易之后才能发起分账请求。以下是基于`wechatpay-node-v3`的一个简单示例代码片段: ```javascript const { WechatPay } = require('wechatpay-node-v3'); // 初始化WechatPay实例 let wechatPay = new WechatPay({ mchid: 'YOUR_MERCHANT_ID', serialNo: 'CERTIFICATE_SERIAL_NUMBER', privateKeyPath: '/path/to/your/private/key.pem', // 商户私钥路径 certDir: '/path/to/certificates/', // 平台证书目录 }); async function createProfitSharing(orderId, receivers) { try { const result = await wechatPay.profitsharing.create({ transaction_id: orderId, out_order_no: generateOutOrderNumber(), // 自定义外部单号生成逻辑 receivers: [ ...receivers.map(receiver => ({ type: receiver.type || "MERCHANT", account: receiver.account, amount: Math.floor(receiver.amount * 100), // 转换成分单位 description: "利润分成" })) ] }); console.log(`分账结果:${JSON.stringify(result)}`); return result; } catch (error) { console.error(error); } } ``` 这段代码展示了如何通过`profitsharing.create()`方法向多个接收方分配收益。需要注意的是,实际应用中应当根据业务需求调整参数设置以及错误处理机制。 此外,有关更详细的配置选项和API说明,请参阅官方提供的[微信支付V3 API文档](https://pay.weixin.qq.com/wiki/doc/api/allocation.php?chapter=8_7&index=1)[^3]。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

a408492801

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值