nodejs开发微信支付之退款结果通知url

  • 前言
  • 步骤
    • 1.先对加密串A进行base64解密
    • 2.对商户key做md5,得到32位小写key
    • 3.用key*对加密串B做AES-256-ECB解密

前言

退款成功后返回的xml格式示例

步骤

加密字符串是req_info
解密之前,我们需要把xml格式转换为json格式:

const notificationXML = ctx.request.body.xmlconst notificationJSON = {}for (let [key, value] of Object.entries(notificationXML)) {notificationJSON[key] = value[0]}let notionResult = notificationJSON['req_info']

1.先对加密串A进行base64解密

  let resultInfo = Buffer.from(notionResult, 'base64')

2.对商户key做md5,得到32位小写key

 const key = 'KmfuRzZM9lfxHJL'const md5Key = await crypto.createHash('md5').update(key).digest('hex')

3.用key*对加密串B做AES-256-ECB解密

我们将解密过程封装成一个方法,这样调用起来比较方便

/*** aes解密微信回调通知* @param data 待解密内容* @param key 必须为32位私钥* @returns {string}*/
exports.decryption = function (data, key, iv) {if (!data) {return ''}iv = iv || ''var clearEncoding = 'utf8'var cipherEncoding = 'base64'var cipherChunks = []var decipher = crypto.createDecipheriv('aes-256-ecb', key, iv)decipher.setAutoPadding(true)cipherChunks.push(decipher.update(data, cipherEncoding, clearEncoding))cipherChunks.push(decipher.final(clearEncoding))return cipherChunks.join('')
}

解密方法封装好了,那就开始调用

const fxp = require('fast-xml-parser')let iv = Buffer.alloc(0) // 设置偏移量let decxml = exports.decryption(resultInfo, md5Key, iv) // 解码console.log(decxml)let reg = new RegExp('root>', 'g')decxml = decxml.replace(reg, 'xml>') // 转化为xml格式console.log(decxml)const xml2json = fxp.parse(decxml) // xml转对象console.log(xml2json)

剩下的就看自己的业务需求了,值都取出来了想干嘛干嘛,服务号的通知什么的也很容易,退款通知这种,下一个博客见。
来自小仙女的代码之路.
附带大神的链接 https://www.oecom.cn/nodejs-wechat-pay-4/

nodejs开发微信支付之接收退款申请通知相关推荐

  1. nodejs实现微信支付小微商户申请入驻接口

    微信支付小微商户可以通过小程序<微信买单服务商助手>来进件,也可以通过API接口来进件(详情可查阅小微商户专属接口文档). 2种方式进件后的商户是有区别的 不同进件方式下的小微商户对比   ...

  2. 微信小程序云开发微信支付、订单查询、申请退款

    微信小程序云开发微信支付 使用云开发微信支付功能的前提 统一下单 查询订单 申请退款 常见问题总结: 使用云开发微信支付功能的前提 小程序主体为企业或者工商个体户 小程序完成了微信认证 小程序接入微信 ...

  3. php开发微信商户平台支付宝支付,不用申请服务号就可以开发微信支付/支付宝/QQ钱包支付!附:直接可用的代码+demo...

    我们知道,开发微信支付需要申请服务号并且需要一系列的资料才可以开通.怪麻烦的,现在我们可以用第三方开放的免签约微信支付接口,支付宝接口和QQ钱包接口,实现实时到帐的微信支付开发. 我们只需要在第三方的 ...

  4. 不用申请服务号就可以开发微信支付/支付宝/QQ钱包支付!附:直接可用的代码+demo...

    我们知道,开发微信支付需要申请服务号并且需要一系列的资料才可以开通.怪麻烦的,现在我们可以用第三方开放的免签约微信支付接口,支付宝接口和QQ钱包接口,实现实时到帐的微信支付开发. 我们只需要在第三方的 ...

  5. springboot快速开发微信支付

    springboot快速开发微信支付 1. POM文件添加依赖 <properties><wechat.sdk.version>3.3.7.B</wechat.sdk.v ...

  6. 如何使用easywechat开发微信支付功能

    easywechat是神一样的存在.非常好用.希望大家都能转到这上面来. 用easywechat来开发微信支付功能,步骤如下: 一,需要有一个商品下单页面,页面上有你的商品的信息,还要有购买数量,和一 ...

  7. php 工商银行公众号支付代码_php开发微信支付企业付款实例代码

    企业付款的应用场景: 公众号向已关注用户付款,比如处理退款.财务结算等,本文主要和大家分享php开发微信支付企业付款实例代码,希望能帮助到大家. 说明 1.证书需要用自己的商户里面的证书(注意:证书路 ...

  8. PHP实现小程序微信支付v3版本退款,以及对退款订单进行查询

    PS:本篇文章仅用作对小程序微信支付v3版本的退款流程以及对退款订单进行查询的流程展示,如要用于实际,还请自行修改代码 文章中调用的API_Connect.php 与API_v3Connect.php ...

  9. PHP微信根据订单号查询支付结果,9. PHP接入微信支付订单、退款订单、转款订单的查询...

    微信并未提供一个统一的查询接口.对应每种查询均需要不同的api.为了便于大家在项目中使用,忽略细节.对以上三种进行了封装.通过工厂的方式降低调用成本. $wxconfig = [ 'app_id' = ...

最新文章

  1. [SharePoint 2010] Configuration SMTP for SharePoint 2010
  2. java面向对象基础复习
  3. 跟我一起写 Makefile(六)
  4. pycharm活动模板
  5. 【LOJ】#2014. 「SCOI2016」萌萌哒
  6. php 静态方法特点,浅析php静态方法与非静态方法的用法区别
  7. linux中date命令设置系统时间的方法-转
  8. python基础: day4作业计算器
  9. Tricks(三十八)—— 在不计算欧式距离的前提下判断点到两点的距离哪个更近
  10. ai能不能同时切割多个对象_今天才发现,AI有这9个隐藏技能...
  11. 【故障处理】ORA-19809错误处理
  12. 基于Android Studio和Gradle 的小米便签配置和安装
  13. java可达性_java 垃圾回收总结(可达性分析 引用分类
  14. UE高级性能剖析技术(三)-- Android内存分布和优化
  15. 对潇潇暮雨洒江天,一番洗清秋。渐霜风凄紧,关河冷落,残照当楼。是处红衰翠减,苒苒物华休。唯有长江水,无语东流。不忍登高临远,望故乡渺邈,归思难收。叹年来踪迹,何事苦淹留?想佳人,妆楼颙望,误几回、天际
  16. Spring读源码系列番外篇04----类型转换--上---老旧的PropertyEditor
  17. 动手下载网易课程视频 -- 正式下载
  18. java 回调机制分为:异步回调 同步回调
  19. 论文阅读《A Large Dataset to Train Convolutional Networks for Disparity, Optical Flow, and Scene Flow Es》
  20. Crack:Aspose.Slides for .NET 22.12.x

热门文章

  1. h5获取微信授权登录
  2. Python 把十进制转换为二进制(或八进制、十六进制)
  3. 【Android】如何设置应用强制横屏或竖屏
  4. 【seeprettyface.com】数据集:黄种人/动漫人物/自拍照/网红脸人脸数据集
  5. angular ng2-file-upload 上传多视频、多图片,并本地预览;后端C#接收
  6. 2022-2028年中国生物制药产业产销状况与发展规划建议报告
  7. 微信小程序:如何制作一个带动画效果的按钮
  8. php mysql 添加字段,php mysql如何增加字段
  9. 谷歌气球 simplekml 《八》地图动画之旋转动画的制作-全网唯一
  10. TIFF图像文件(一):文件结构