位置: 编程技术 - 正文

详解NodeJs支付宝移动支付签名及验签(nodejsapi)

编辑:rootadmin

推荐整理分享详解NodeJs支付宝移动支付签名及验签(nodejsapi),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:nodejs 支付宝支付,nodejs接入微信支付,nodejs 知乎,nodejs 支付宝支付,nodejsapi,node.js微信支付,node.js微信支付,nodejs 支付宝支付,内容如对您有帮助,希望把文章链接给更多的朋友!

非常感谢 : 的文章,如果不是找到这篇文章我可能还要继续坑几天,代码也基本都是照着他的搬过来的,不过支付宝移动支付文档写的非常糟糕而且没有node的SDK和demo,写起来异常痛苦..好在找到了这篇文章顺便折腾了一下午支付宝的技术人员总算把移动支付整个流程给做完了,所以就顺便记录一下自己遇到的坑,和对移动支付整个流程的梳理。

支付宝给的流程图还是很清晰的,其实基本流程就是

用户向服务器请求一个付款 服务器生成一个带签名的订单发送给客户端 客户端通过这个订单向app sdk请求付款 sdk把用户引入支付宝付款界面进行支付 支付成功后支付宝向前端返回支付成功结果,并且向服务器发送一个支付通知 服务器接收通知并且验证是否是支付宝发送的成功结果

app客户端需要做的很简单:

向自己的服务器请求一个订单, 接收到订单后,向支付宝sdk发情一个支付请求 交易结束后返回一个成功或者失败

服务器做的事情稍微多一点(注意:服务端需要存放应用的私钥进行签名,还有支付宝的公钥进行验签):

1.接收到客户端请求时候,生成一个带签名订单返回给客户端,中间的步奏有

1) 把相应的配置数据生成一个数组,再把数组的数据生成一个有序的字符串

2) 将这组支付串进行RSA-SHA1算法,得到的结果再与存在服务端的私钥进行签名

详解NodeJs支付宝移动支付签名及验签(nodejsapi)

3) 有序的字符串+得到的签名+签名方法就是生成的订单,将这组订单返回给客户端

2.前半段的工作就做完了,接下来如果前端支付成功,支付宝会向我们预留好的回调接口发送一个POST请求,让我们验证用户是否支付成功

1) 将支付宝发送过来的数据生成一个有序的字符串

2) 将获取的数据进行hash然后根据公钥进行对签名的有效应验证,返回true和false

3) 如果验签成功再生成支付宝通知url,来验证是否是支付宝发来的通知(支付宝的验证一大堆,脑壳都痛了),如果有数据则说明确实是支付宝发来的通知,这次交易有效

这样整个流程就跑完了,代码原博客都有,这里最多只是有些改成了sails的写法,主要写一下这次遇到的几个坑和值得注意的几个地方

1. 由于移动支付的文档描述不清楚,私钥其实上上传到账户信息的mapi网管产品密钥里:

而不是上传到应用的密钥里

2. 移动支付只支持RSA(SHA1)

3. ./是在sails里获取的到根目录下的密钥(有点搞不懂sails的这个路径)

4. 生成订单时候的有序字符串格式是body="测试" ,有双引号,但是验签生成的有序字符串里不能有双引号

标签: nodejsapi

本文链接地址:https://www.jiuchutong.com/biancheng/374142.html 转载请保留说明!

上一篇:nodejs和php实现图片访问实时处理(node js php)

下一篇:node.js发送邮件email的方法详解(node 发邮件)

  • 应交增值税和未交增值税都有余额
  • 税后工资怎么查
  • 普票加专票超过30万全交税吗2020
  • 工厂外包加工项目
  • 三供一业移交内容
  • 政府补助需要交哪些税
  • 扣缴附加税怎么做分录
  • 金税盘发票打印不全
  • 跨期列支成本费用危害
  • 企业汇算清缴时允许税前扣除的工资是什么
  • 零食发票能抵税吗
  • 外购低值易耗品支付价款16万元
  • 商誉转销会计分录
  • 事业单位结转资金和结余资金区别
  • 因增资扩股导致股价下跌
  • 当月没有销售需要结转成本吗
  • 负债月末正常余额是什么
  • 政府补贴转给其他公司
  • 一般纳税人为什么要开专票
  • 普通发票查不到信息怎么办
  • 小微企业每年可以开多少发票北京
  • 委任方名称代表的是什么意思?
  • 税控盘服务费抵税会计分录
  • 客户扣了一部分不合格产品的货款,请问如何做账呢?
  • 房产公司增值税怎么交
  • 2021年6月更新
  • win7为什么现在不能用了
  • 王者荣耀中苏烈的最强出装
  • 其他应付款和其他应付款对冲
  • 厂家赠送的商品如何走账
  • 贴现息等于什么
  • framework4.0怎么打开
  • 总公司下的分公司如何做账
  • 基于vue的网上商城
  • 如何使用vue
  • php调用变量的符号
  • 包装物应交消费税
  • 学人工智能哪家机构比较好
  • Laravel5权限管理方法详解
  • php实现链式操作实验报告
  • 食堂员工自己吃饭违法吗
  • pdclient
  • apr命令怎么用
  • Google C++ Style中允许使用的Boost库(1) 程序即人生 博客频道 CSDN.NET
  • 提供加工劳务怎么开票
  • 深入理解linux内核
  • 欠对方钱对方公司已注销
  • 公司的融资租赁有哪些
  • 汇算清缴是什么
  • 用人单位性质怎么填
  • 从公司账户转给出纳备注
  • 跨年度退货
  • 列举2-4种特殊销售方式,其销售额如何确认?
  • 应交税费应交增值税已交税金怎么用
  • 收到工程款怎么入账
  • 销售收入包含哪些费用
  • 增值税普通发票查询
  • 工业企业增值税负率一般控制在多少
  • windows server特点
  • windowsserver2008远程桌面怎么打开
  • centos 环境变量
  • apt-get和aptitude
  • windows8怎么装windows10
  • win10 无线热点
  • win 7关闭睡眠
  • linux内核配置文件
  • html5图文混排
  • ubuntu不待机
  • js中new操作符工作原理
  • js中split方法的作用
  • script标签的defer和async
  • 安卓压缩图片
  • Python对象转列表
  • 黑龙江国税局官网
  • 增值税申报表如何填报
  • 税务局绩效奖金多少
  • 如何打印个税缴纳记录
  • 广州国税地税上班时间
  • 考上如皋地税局好吗
  • 税务筹划和纳税申报哪个更容易学
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设