Quantcast
Channel: CSDN博客移动开发推荐文章
Viewing all articles
Browse latest Browse all 5930

微信小程序开发(十)小程序支付-查询退款

$
0
0

应用场景

提交退款申请后,通过调用该接口查询退款状态。退款有一定延时,用零钱支付的退款20分钟内到账,银行卡支付的退款3个工作日后重新查询退款状态。

接口说明

这里写图片描述
这里退款还是根据商户订单号-out_trade_no去微信那边查询

代码实现

/*
 * 根据商户订单号out_trade_no 查询退款
 */
router.all('/api/wxpay/refundQuery', function(req, res, next) {
    var param = req.query || req.params; 
    var out_trade_no = param.out_trade_no;
    console.log('out_trade_no = ' + out_trade_no);

    var nonce_str = getNonceStr();
    var fee = '1';

    var bodyData = '<xml>';
    bodyData += '<appid>' + wxConfig.AppID + '</appid>';
    bodyData += '<mch_id>' + wxConfig.Mch_id + '</mch_id>';
    bodyData += '<nonce_str>' + nonce_str + '</nonce_str>';
    bodyData += '<out_trade_no>' + out_trade_no + '</out_trade_no>';

    var sign = refundQuerySign(
        wxConfig.AppID,
        wxConfig.Mch_id,
        nonce_str,
        out_trade_no,
    );

    bodyData += '<sign>' + sign + '</sign>';
    bodyData += '</xml>';

    var urlStr = 'https://api.mch.weixin.qq.com/pay/refundquery';
    request({
        url: urlStr,
        method: 'POST',
        body: bodyData,
    }, function (error, response, body) {
        if (!error && response.statusCode == 200) {
            var returnValue = {};
            parseString(body, function (err, result) {
                if (result.xml.return_code[0] == 'SUCCESS' && result.xml.result_code[0] == 'SUCCESS') {
                    returnValue.msg = '操作成功';
                    returnValue.status = '100';
                    returnValue.result = result;
                    res.end(JSON.stringify(returnValue));
                } else{
                    returnValue.msg = result.xml.return_msg[0];
                    returnValue.status = '102';
                    returnValue.result = result;
                    res.end(JSON.stringify(returnValue));
                }
            });
        }else{
            res.end(JSON.stringify({
                msg: "请求失败",
                status: "103"
            }));
        }
    })
});

总结

关于小程序支付基本都写完了。
《微信小程序开发(五)小程序支付-统一下单》
《微信小程序开发(六)小程序支付-notify_url》
《微信小程序开发(七)小程序支付-查询订单》
《微信小程序开发(八)小程序支付-关闭订单》
《微信小程序开发(九)小程序支付-申请退款》
《微信小程序开发(十)小程序支付-查询退款》

作者:zhuming3834 发表于2017/6/22 10:41:38 原文链接
阅读:10 评论:0 查看评论

Viewing all articles
Browse latest Browse all 5930

Trending Articles