位置: 编程技术 - 正文

详解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 发邮件)

  • 支付给境外个人的租金
  • 金蝶kis专业版的优缺点
  • 已开普通发票记账联丢失怎么办?
  • 补缴以前年度房产税以及滞纳金
  • 企业对公账户钱怎么取出来
  • 重分类八个对应科目有哪些
  • 印花税购销合同计税金额怎么算
  • 出售交易性金融资产的交易费用计入
  • 建筑公司核定征收是什么意思
  • 营业外收入期末结转
  • 对公账户的钱怎么取出来才不用交税
  • 冲去年其他应付款做管理费用凭证
  • 非征期不能抄报
  • 红包营销活动方案
  • 公司买汽车怎么做内账
  • 国家税务局通用定额发票还能用吗
  • 公司对公账户每年费用
  • 几种更正法
  • 事业单位购买固定资产费自行
  • 维修税控设备分录
  • ah股溢价是什么意思 搬砖
  • 资产减值损失是什么类科目
  • 软件产品即征即退申请表
  • 房地产开发企业资质证书
  • 职工福利费的会计科目是什么
  • 印花税申报后怎么缴费
  • 记帐凭证由谁填制
  • hotkey osd driver可以卸载吗
  • 付临时工资怎么入账
  • c语言 cmd
  • 产品工人工资属于制造费用吗
  • 多表联动查询
  • 油卡预付卡发票能入费用吗怎么入账
  • pytorch怎么入门
  • dematel模型有什么缺点
  • geth命令行
  • 勘察设计费怎么入账
  • 长期借款主要包括哪些
  • 织梦会员系统
  • sql随机函数rand怎么用
  • 合同权利义务包含债务吗
  • mysql改造
  • 资产的计税基础通俗理解
  • 代开普通发票需提供哪些材料?
  • 进项留抵月末要结转吗
  • 年末资产减值损失可以税前扣除吗
  • 公司账户的钱怎么合理的转出来
  • 财务报表未备案可以不填吗
  • 职工体检可以从工会经费支出
  • sql忽略null
  • mysql 添加外键
  • sqlserver数据库版本号怎么查
  • win8.1鼠标没反应
  • mac os 删除
  • Win7的sysprep工具怎么用 win7自带sysprep工具重置系统方法
  • win8 重置
  • win1020h2正式版
  • win7文件访问被拒绝怎么办
  • win10注销系统会怎么样
  • PasSrv.exe - PasSrv是什么进程 有什么用
  • win7系统电脑开机黑屏
  • win8打游戏卡怎么办
  • win7系统64位安装打印机的方法
  • win10用户账户guest
  • cocos2dx-js
  • jquery插件大全
  • unity接入安卓sdk
  • 一波JavaScript日期判断脚本分享
  • three.js入门指南
  • javascript Math.random()随机数函数
  • 深入理解计算机系统 电子书
  • arraylist100扩充几次
  • jquery网页
  • androidday3
  • 使用jQuery制作动画与特效及插件的应用
  • python调用ch
  • 广东电子税务局财务报表在哪里查询
  • 营业收入是含增值税的收入吗
  • 免税发票可以抵多少税
  • 东莞国税稽查分局局长
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设