thinkPHP实现微信支付之退款,附demo示例

此篇文章主要介绍了ThinkPHP6框架下整合微信支付之退款功能

手册里面有的东西不多介绍,请求参数、返回结果之类的请移步官方手册查看。本文主要是通过一个demo实例进行讲解微信支付退款接口。

手册地址:https://pay.weixin.qq.com/wiki/doc/api/native.php?chapter=9_4


注意:

  1. 交易时间超过一年的订单无法提交退款

  2. 微信支付退款支持单笔交易分多次退款,多次退款需要提交原支付订单的商户订单号和设置不同的退款单号。申请退款总金额不能超过订单金额。 一笔退款失败后重新提交,请不要更换退款单号,请使用原商户退款单号

  3. 请求频率限制:150qps,即每秒钟正常的申请退款请求次数不超过150次,错误或无效请求频率限制:6qps,即每秒钟异常或错误的退款申请请求不超过6次

  4. 每个支付订单的部分退款次数不能超过50次

  5. 如果同一个用户有多笔退款,建议分不同批次进行退款,避免并发退款导致退款失败

  6. 申请退款接口的返回仅代表业务的受理情况,具体退款是否成功,需要通过退款查询接口获取结果。

  7. 双项证书这里要填物理路径,也就是绝对路径。

微信支付退款接口流程介绍:

  1. 将基本请求参数和随机字符串(见下文)写入到数组

  2. 生成签名(按照字典序排序)写入数组

  3. 将数组转为xml包

  4. 提交CURL请求(POST),必须携带双向证书。

  5. 微信返回数据

生成随机字符串方法和签名生成方法见下文微信支付类下载地址。

微信支付退款接口必填请求参数:

  1. appid 公众号ID

  2. mch_id 商户号

  3. nonce_str 随机字符串

  4. out_trade_no商户订单号、transaction_id微信支付订单号,二选一

  5. out_refund_no 商户退款单号

  6. refund_fee 退款金额(单位为分)

  7. total_fee 标价金额(单位为分)

  8. sign 签名

此方法一共涉及一个类文件,为WxPay(微信支付类),下载地址见下文。

// 退款
public function tuikuan(){
    $content['order_sn'] = 'wx2021022653651423'; //商户订单号
        $order['uid'] = '15564343543'; //商户退款单号
        $order['refundMoney'] = '0.01'; //退款金额 单位为元
        $order['amount'] = '9.9'; //订单金额 单位为元
    // 实例化支付类,并传入参数
    $wx = new WxPay("");
    //  微信的金额单位为分,所以要乘100!!!
    $content =$wx->tuiKuan("{$order['order_sn']}","{$order['uid']}","{$order['refundMoney']}"*100,"{$order['amount']}"*100);
    // 判断是否退款成功
    if($content['result_code']=="SUCCESS"){
            echo "退款成功" . $content['refund_fee']/100 . "元";
        }
}

image.png

文章:微信支付类下载二维码类下载

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

形影相吊.

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

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

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

打赏作者

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

抵扣说明:

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

余额充值