干货-Google支付后台验证操作流程【业务后台-GP后台流程】

2024-09-04 17:58

本文主要是介绍干货-Google支付后台验证操作流程【业务后台-GP后台流程】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

        整个开发背景是前端在调用完google play支付流程后,需要后台验证支付结果以及在自己的服务生成订单相关信息。

由此着手对google后台验证的调研,首先官方流程:
点我查看官方流程

整个操作流程如下:

1、在开发者后台中启用Google Play Android Developer项目
Google Play Android Developer项目
2、在Google APIS中选择Google Play Android Developer项目–【凭据】–【OAuth同意屏幕】

注:只要填入信息即可,无需验证,但一定要添加【域名(已获授权的网域)】

例如:使用这个地址比较好,请求成功率高

http://localhost:8080

在这里插入图片描述
3、创建OAuth客户端凭据
在这里插入图片描述

4、创建好Oauth客户端ID后管理者用项目最高权限的GP账号登录,访问:

https://accounts.google.com/o/oauth2/auth?scope=https://www.googleapis.com/auth/androidpublisher&response_type=code&access_type=offline&redirect_uri=http://localhost:8080&client_id=123122121

复制链接后将下面的两个参数value修改成分配的正确值即可

redirect_uri=已授权的重定向URI(建议使用:http://localhost:8080)
client_id=google分配的客户端ID

以上链接登录成功后,会在浏览器的地址栏中显示code,只要拿出code的值即可:
在这里插入图片描述

注:有链接会被转义,比如/会被转成%2F,就如以上参数值,copy下来后手动改一下:
Code=4/bAEGOfkpDnG5hhtv8E7FSkKPp-oFVQpTPeg8l_jWjKQd5BaOviZLyimEywJR9ptEoFtRqb95sZh4yXfRLI81BbM

Tip:文中所提到的模拟数字含义:

123122121=client_id=客户端 ID
123456789=client_secret=客户端密钥

在这里插入图片描述
5、获取到code后发送post请求,以下POST请求实例以postman工具来进行操作

注:一定要按步骤来才能到发post请求这一步

请求头Content-Type = application/x-www-form-urlencoded 以表单的形式传参

请求以下接口获得refresh_token:

https://accounts.google.com/o/oauth2/token

注:只有在第一次请求时会返回refresh_token,之后将不会返回了,所以在获得返回的refresh_token后,请妥善保存此token。以后的请求中都不会再出现,对于当前创建的凭证账号是唯一且永久有效的,可以存放到配置文件(或者写到数据库),以备后用

参数:

grant_type=authorization_code为固定值
code=第4步中获取到的code值,
client_id=客户端ID,(123122121)
client_secret=客户端密钥,(123456789)
redirect_url=重定向链接(http://localhost:8080)

注:返回结果中的expires_in是指access_token的时效,为3600秒

在这里插入图片描述

第一次请求会获得refresh_token,妥善保存

6、携带refresh_token可获取access_token,POST请求访问

请求头Content-Type = application/x-www-form-urlencoded 以表单的形式传参

再次请求以下接口时只会获得access_token:

https://accounts.google.com/o/oauth2/token

参数:

grant_type=refresh_token为固定值,
client_id=客户端ID,(123122121)
client_secret=客户端密钥,(123456789)
refresh_token=第5步中获取到的refresh_token值,

在这里插入图片描述
7、验证:GET请求
请求以下接口时查询获得商品信息:

https://androidpublisher.googleapis.com/androidpublisher/v3/applications/{packageName}/purchases/products/{productId}/tokens/{purchaseToken}?access_token=access_token

上面的http请求中的参数信息需要修改为以下内容:

packageName=需要查询的应用ID(包名、gradle中的applicationId )
productId=开发者后台中创建好的商品ID
purchaseToken=订单中purchaseToken
access_token=第6步中获得的access_token
注:如果客户端是用V2API进行支付的,直接使用上方链接即可,如果是v3api时,需要将链接中的v2改成v3,否则查询失败

返回数据:
在这里插入图片描述
到这里就结束了,把流程梳理好后,做起来就不难了,大家喜欢这篇文章的话,可以麻烦点个赞和加个关注咩?,我也希望这篇文章能够帮助更多的小伙伴。但是有一点要说明哦,

码字不容易哦,如果要收藏啥的,转发时请麻烦标明出处

这篇关于干货-Google支付后台验证操作流程【业务后台-GP后台流程】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1136633

相关文章

Security OAuth2 单点登录流程

单点登录(英语:Single sign-on,缩写为 SSO),又译为单一签入,一种对于许多相互关连,但是又是各自独立的软件系统,提供访问控制的属性。当拥有这项属性时,当用户登录时,就可以获取所有系统的访问权限,不用对每个单一系统都逐一登录。这项功能通常是以轻型目录访问协议(LDAP)来实现,在服务器上会将用户信息存储到LDAP数据库中。相同的,单一注销(single sign-off)就是指

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

业务中14个需要进行A/B测试的时刻[信息图]

在本指南中,我们将全面了解有关 A/B测试 的所有内容。 我们将介绍不同类型的A/B测试,如何有效地规划和启动测试,如何评估测试是否成功,您应该关注哪些指标,多年来我们发现的常见错误等等。 什么是A/B测试? A/B测试(有时称为“分割测试”)是一种实验类型,其中您创建两种或多种内容变体——如登录页面、电子邮件或广告——并将它们显示给不同的受众群体,以查看哪一种效果最好。 本质上,A/B测

业务协同平台--简介

一、使用场景         1.多个系统统一在业务协同平台定义协同策略,由业务协同平台代替人工完成一系列的单据录入         2.同时业务协同平台将执行任务推送给pda、pad等执行终端,通知各人员、设备进行作业执行         3.作业过程中,可设置完成时间预警、作业节点通知,时刻了解作业进程         4.做完再给你做过程分析,给出优化建议         就问你这一套下

C++ | Leetcode C++题解之第393题UTF-8编码验证

题目: 题解: class Solution {public:static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num &

C语言 | Leetcode C语言题解之第393题UTF-8编码验证

题目: 题解: static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num & MASK1) == 0) {return

easyui同时验证账户格式和ajax是否存在

accountName: {validator: function (value, param) {if (!/^[a-zA-Z][a-zA-Z0-9_]{3,15}$/i.test(value)) {$.fn.validatebox.defaults.rules.accountName.message = '账户名称不合法(字母开头,允许4-16字节,允许字母数字下划线)';return fal

easyui 验证下拉菜单select

validatebox.js中添加以下方法: selectRequired: {validator: function (value) {if (value == "" || value.indexOf('请选择') >= 0 || value.indexOf('全部') >= 0) {return false;}else {return true;}},message: '该下拉框为必选项'}

kubelet组件的启动流程源码分析

概述 摘要: 本文将总结kubelet的作用以及原理,在有一定基础认识的前提下,通过阅读kubelet源码,对kubelet组件的启动流程进行分析。 正文 kubelet的作用 这里对kubelet的作用做一个简单总结。 节点管理 节点的注册 节点状态更新 容器管理(pod生命周期管理) 监听apiserver的容器事件 容器的创建、删除(CRI) 容器的网络的创建与删除

消除安卓SDK更新时的“https://dl-ssl.google.com refused”异常的方法

消除安卓SDK更新时的“https://dl-ssl.google.com refused”异常的方法   消除安卓SDK更新时的“https://dl-ssl.google.com refused”异常的方法 [转载]原地址:http://blog.csdn.net/x605940745/article/details/17911115 消除SDK更新时的“