(第一次接触支付,理解可能也不是很深,欢迎批评指正)
paypal是目前全球最大的在线支付工具,就像国内的支付宝一样,是一个基于买卖双方的第三方平台。
PayPal API是基于HTTP的restful API,使用OAuth 2.0进行授权。API请求和响应主体采用json格式。
*环境准备
* 注册paypal账号
(1)在浏览器输入“https://www.paypal.com”,页面跳转,进行注册
(2)选择“创建个人账户”,根据要求填写信息,注册完去邮箱激活
* 注册paypal开发者账号
(1)在浏览器输入“https://developer.paypal.com”,并登陆创建好的账号登录
* 创建两个测试用户
(1)登录成功之后,点击Sandbox下的Accounts
(2) 进入Accounts洁面后,可以看到系统有两个生成好的测试账号,但是我们不要用系统给的测试账号,很卡,自己创建两个账号。
系统生成的两个测试账号(3)点击“Create Account” , 创建测试用户
创建测试用户填完账户信息即可, 先创建一个“ PERSONAL”类型的用户,国家一定要选“China”,账户余额自己填写。接着创建一个“BUSINESS”类型的用户,国家一定要选“China”,账户余额自己填写,创建好之后可以点击测试账号下的”Profile“,可以查看信息,如果没加载出来,刷新 。
手动创建的测试账号用测试账号登录测试网站查看,注意!这跟paypal官网不同!不是同一个地址,在浏览器输入:https://www.sandbox.paypal.com 在这里登陆测试账户
* 创建应用,生成用于测试的clientID 和密钥
创建应用时,PayPal会为沙盒和实时环境为您的应用生成一组OAuth客户端ID和机密凭据。您Authorization在get访问令牌请求中的标头中传递这些凭据。通过持票人令牌,您可以代表资源所有者并获得资源所有者的批准。
(1)点击左边导航栏Dashboard下的My Apps & Credentials,创建一个账号,下图是我已经创建好的
沙箱账号(2) 然后到下边的创建App
这是我创建的“ai_server”App:
创建应用(3)点击刚创建的App"ai_server", 注意看到”ClientID“ 和”Secret“(Secret如果没显示,点击下面的show就会看到,点击后show变为hide)
App生成的clientId和密钥******环境准备工作基本完成,接下来需要获取访问令牌(使用访问令牌进行身份验证),要获取访问令牌,请在获取访问令牌调用中传递OAuth凭据。要进行此调用,您可以在命令行或Postman应用程序上使用cURL。
以postman为例:
凭据生成过程 获得令牌凭据二、客户端集成的工作方式如下:
1. 您的买家点击了PayPal按钮。
2. PayPal按钮调用PayPal API来设置付款。
3. 该按钮在浏览器中启动结帐流程。
一个客户端的整合是整合PayPal支付的最快方式。它不需要Web服务器来设置和执行付款。相反,PayPal Checkout按钮可直接从您的浏览器设置和执行付款。
三、REST API
本项目支付调用的是PayPal的SDK,主要关注Create 和 Execute 两个接口,使用SDK的好处是通信过程中只要按照格式要求去请求接口就OK了,不需要牵扯到加密等复杂部分。以下是项目主要请求的内容和格式,以及返回的内容和格式。(主要来自Payments API,为图方便而记录下来,有需要了解更多的的可以去参考官方文档啦)
Create payment
Create请求的格式和内容:
以postman 为例:
支付认证过程(tips:访问凭据过期可以再去生成)
支付的请求数据中的return_url,是当你支付成功后所跳转的url,后面会用到
支付请求成功返回的数据
支付成功返回数据声明:支付请求成功返回的数据链接中,将页面重定向至该url支付页面,进行支付授权,并确认支付。
确认支付的url将approval_url放入浏览器中 ,进行付款(付款之前需要你去登录测试个人账号去付款)
登录个人账号
支付信息
支付过程在支付成功的那一刻,跳转之前设定好的URL页面里面(是请求数据中return_url),并获得支付成功的PayerID等数据
支付成功在支付请求成功的返回链接数据中获取函数execute的该url:
授权批准通过买家payer_id去观察付款状态:
授权订单 买家同意本次交易获取到execute的返回值,主要关注state关键字。
state状态返回的值有created,approved,failed,以此来判断支付的状态。到了这一步,支付的整个流程就全部走通啦!
说到这里不得不在提醒一下,刚开始支付成功是返回的数据状态为“state:created”,只是这笔交易刚创建而已,上图:
交易创建成成功当买家同意本此交易,才是真正的本场交易完成。
在结尾处咱们可以看下测试账号中的金额,是否符合刚才这份交易,首先登录测试个人账号:
测试个人账号噔噔噔噔,付款成功,完美!
接下来看下商家账号中是否收到该次交易的金额,登录你的是测试商家账号
测试商家账号收款金额到账,更加完美!
网友评论