博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
支付接口教程,详解支付宝接口(二)
阅读量:6938 次
发布时间:2019-06-27

本文共 1362 字,大约阅读时间需要 4 分钟。

支付宝的接口向来集成过程都让人觉得比较舒服,只有APP支付相对复杂,但也只是配置上复杂一些,只要清楚原理相信也不是什么难事。下面是以前介绍双钥加密原理的传送门:

在这篇文章的引导下,我们来看一种真实的支付接口加密情景。
支付宝APP支付
为了确定商户和支付宝双方的身份数据的安全,双方都会进行校验,也就是同时存在两套公私钥,支付宝一套,商家一套。画个图就是这样子的:

img_f66d0f9519f73bd49cb9c4ea26cb4bd1.jpe
支付接口教程,详解支付宝接口(二)
这个过程中有两个关键点:

  • 支付宝用商家公钥解密,确认商家身份和发起支付数据的安全
  • 商家用支付宝公钥解密,确认支付宝身份和支付成功数据的安全

由此,在理论上可以推出,我们在配置阶段需要做的工作有以下几点:

  1. 利用工具生成自己(商家)的公钥和私钥
  2. 将生成的公钥告诉支付宝
  3. 下载支付宝提供的公钥

让我开始具体的流程。

接口申请

接口申请的地址为蚂蚁金服开放平台,在此之前需要成为入驻商家(这一步得客户去做)。

然后我们在开放平台创建一个应用

img_6e592fc222277dbe5d0681bc4a3cb0a7.jpe
支付接口教程,详解支付宝接口(二)
创建完之后我们查看应用详情,
添加应用功能
img_fd7c17828cbfe71049727b3741d3136e.jpe
支付接口教程,详解支付宝接口(二)
在靠下的位置找到APP支付,根据提示一步步完成
签约
img_61b6a6ddaa3c366be183cfb3596e6404.jpe
支付接口教程,详解支付宝接口(二)
注意:签约之后你会获得一个partner_id,也就是收款账户id

接口配置

首先我们得去准备商家的公钥和私钥,这个是需要自己生成的:

我们下载官方提供的生成工具,双击打开:

img_6f698b2869f301640d6cc77f834bc201.jpe
支付接口教程,详解支付宝接口(二)
秘钥格式和秘钥长度按照上图选择即可,点击生成之后可以看到工具提示秘钥保存的路径。
注意:通常情况下Mac用户是无法打开工具的,需要去
设置-》安全与隐私中设置允许打开所有开发者的应用。

先把我们的生成的公钥告诉支付宝,下面这张图是重点:

img_00f5fb47a98059b58a143763967f4f1f.jpe
支付接口教程,详解支付宝接口(二)
注意:这个页面的入口请注意右上角的箭头,需要把鼠标放到右上角小头像那里,然后点击弹出框中的账号管理。

点击左侧开放平台秘钥,这里顺手先把APPID记录下来。

之后,点击RSA2(SHA256)后面的查看应用公钥,在这里把刚才生成的商家公钥填进去。
最后,点击查看支付宝公钥,在这里把支付宝公钥记录下来。
最最后,再顺手把授权回调地址配置一下,也就是支付宝异步通知的地址。

接口集成

在这步之前,请确保你已经正确的完成下面几件事:

  1. 获取APPID
  2. 准备好商户的私钥
  3. 准备好支付宝公钥
  4. 已经上传了商户公钥到支付宝
  5. 已经配置好了授权回调地址
  6. 你已经签约完成并且准备好了partner_id(也称seller_id)

集成及调试步骤如下:

  1. 构造支付参数
  2. 使用商户私钥对参数进行签名
  3. 把签名和签名方式附在支付参数后面,通过接口传递给APP
  4. (抱歉,我是服务端视角,并不知道APP那边的故事)
  5. 接收支付宝异步回调并使用支付宝公钥进行验证

和微信APP支付一样,支付宝APP接口也并不会提示明确的错误,我们只能做的过程中加倍认真,然后多阅读文档。

注意:千万不要去检查签名和验证签名的过程是否正确,绝大部分情况出错都是参数和配置的错

最后

支付宝APP的集成代码,和我们之前总结过的支付接口通用模式是符合的,感觉距离实现通用支付类又近了一步。


以上内容属于作者原创,特此声明,如需转载,请留言取得同意

你可能感兴趣的文章
js 进阶 10 js选择器大全
查看>>
前端可编辑表格插件有哪些
查看>>
python学习day4之路
查看>>
Python 进阶_OOP 面向对象编程_静态方法和类方法
查看>>
Python 笔试集(2):你不知道的 Python 整数
查看>>
python学习笔记10(Python的内存管理)
查看>>
ES6系列_10之Symbol在对象中的作用
查看>>
EntityFramework获取数据库的时间
查看>>
getBoundingClientRect 获取某个元素信息
查看>>
Facebook 架构学习
查看>>
Java 多线程(三)—— 线程的生命周期及方法
查看>>
AngularJS学习总结
查看>>
MapReduce实现两表join
查看>>
怎么样去优化我们的SQL语句
查看>>
Java 代理模式(一) 静态代理
查看>>
应用缓存
查看>>
【二分答案】【最大流】bzoj1305 [CQOI2009]dance跳舞
查看>>
【AC自动机】【矩阵乘法】【等比数列】hdu2243 考研路茫茫——单词情结
查看>>
【动态规划】bzoj1270 [BeijingWc2008]雷涛的小猫
查看>>
Centos中IP与DNS手动设置方法
查看>>