nodejs实现微信小程序的退款

申请退款

微信小程序退款参考资料 申请退款,简单的流程也来拉出来溜溜 ,毕竟自己写的比文档稍微条理清楚,哈哈哈!来自小仙女魔性的笑😊

双向证书的认证

我们这边不是php环境。所以只需要一个证书就好(p12格式)
按照以下路径下载:微信商户平台(pay.weixin.qq.com)–>账户中心–>账户设置–>API安全

post请求微信接口(个别参数获取方式)

随机字符串生成

  const nonceStr = _.upperFirst(_.sampleSize('ABCDEFGHIJKLMNOPQRSTUVWXYZ012356789', 5 + _.random(1, 4)).join(''))

签名

点击链接查看生成签名

  1. 将集合M内非空参数值的参数按照参数名ASCII码从小到大排序(字典序),使用URL键值对的格式(即key1=value1&key2=value2…)拼接成字符串stringA。
    const stringSignTemp = `appid=${this._refund.appid}&mch_id=${this._refund.mch_id}&nonce_str=${nonceStr}&notify_url=${this._refund.notify_url}&out_refund_no=${outrefundno}&refund_desc=${refunddesc}&refund_fee=1&total_fee=1&transaction_id=${transactionId}&key=${this._refund.key}`
  1. 在stringA最后拼接上key得到stringSignTemp字符串(上面已添加key),并对stringSignTemp进行MD5运算,再将得到的字符串所有字符转换为大写,得到sign值signValue。
const sign = crypto.createHash('md5').update(stringSignTemp).digest('hex').toUpperCase()

return回的xml格式,示例:

 const xmlRequest = `<xml>
      <total_fee>1</total_fee>
      <refund_fee>1</refund_fee>
    </xml>
    `

退款成功

引入

const request = require('request-promise-native')
const parseString = require('xml2js').parseString
const util = require('util')
const parseStringPromise = util.promisify(parseString)
   const options = {
      method: 'POST',
      url: 'https://api.mch.weixin.qq.com/pay/unifiedorder',// 退款请求的url
      body: xmlRequest, //返回的内容
      json: false,
      agentOptions: {
        pfx: fs.readFileSync('refundcert/apiclient_cert.p12'),//存储证书的路径
        passphrase: this._refund.mch_id //商户号
      }
    }
    const response = await request(options)
    const responseJSON = await parseStringPromise(response)
    const responseXML = responseJSON.xml
    const result = {}
    for (let [key, value] of Object.entries(responseXML)) {
      result[key] = value[0]
    }
    return result

当然还有退款结果通知url (下一篇博客哦,够详细的)

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值