# GoogleBilling
**Repository Path**: forgetboy/GoogleBilling
## Basic Information
- **Project Name**: GoogleBilling
- **Description**: 基于com.android.billingclient:billing:1.2,对整个支付流程进行封装。
- **Primary Language**: Android
- **License**: Apache-2.0
- **Default Branch**: master
- **Homepage**: https://github.com/TJHello/GoogleBilling
- **GVP Project**: No
## Statistics
- **Stars**: 0
- **Forks**: 16
- **Created**: 2021-12-06
- **Last Updated**: 2021-12-06
## Categories & Tags
**Categories**: Uncategorized
**Tags**: None
## README
# GoogleBilling 1.2.2.13 [](https://jitpack.io/#TJHello/GoogleBilling)
#### 基于com.android.billingclient:billing:1.2.2,对整个支付流程进行封装。
##### QQ群交流:425219113(计算机语言交流)
**提醒:从2021年8月2日开始,所有新应用都必须使用Billing Library版本3或更高版本。到2021年11月1日,对现有应用程序的所有更新都必须使用Billing Library版本3或更高版本。**
##### 【BillingEasy-0.1.1】[全新设计的内购聚合,同时支持华为内购与谷歌内购](https://gitee.com/TJHello/BillingEasy)
##### [最新版3.0.0.1入口](https://github.com/TJHello/GoogleBilling/tree/3.0/) (2021年8月2日开始强制使用)
##### [测试版2.0.3.10入口](https://github.com/TJHello/GoogleBilling/tree/2.0/)
##### [测试版1.2.2.22入口](https://github.com/TJHello/GoogleBilling/tree/1.2.2-v2/)
**1.2.2.22改动**
- 重写自动消耗逻辑,改为每次购买成功,或者查询到未处理订单时,由使用者决定是否自动消耗。
- 增加onRecheck接口,返回未处理的有效订单
- 用内购id来发起订阅,或者用订阅id来发起内购时,会抛出异常提醒使用者。
**自荐一款全平台广告聚合SDK自动集成框架【ADEasy】:[https://blog.csdn.net/u013640004/article/details/105416193](https://blog.csdn.net/u013640004/article/details/105416193)**
**友情链接一款IOS内购封装【[DYFStoreKit](https://github.com/dgynfi/DYFStoreKit)】【[DYFStore](https://github.com/dgynfi/DYFStore)】**

---
### =================使用方法=================
- API接入
```groovy
//Project
allprojects {
repositories {
...
maven { url 'https://raw.githubusercontent.com/TJHello/publicLib/master'}
}
}
//app
android {
compileOptions {
sourceCompatibility JavaVersion.VERSION_1_8
targetCompatibility JavaVersion.VERSION_1_8
}
}
dependencies {
implementation 'com.TJHello:GoogleBilling:1.2.2.13'
}
```
- 代码示例 [MainActivity](https://gitee.com/tjbaobao/GoogleBilling/blob/master/app/src/main/java/com/tjbaobao/gitee/googlebillingutil/MainActivity.kt)
```kotlin
private lateinit var googleBillingUtil: GoogleBillingUtil
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
GoogleBillingUtil.isDebug(true)
GoogleBillingUtil.setSkus(arrayOf("inappSku"), arrayOf("subsSku"))
googleBillingUtil = GoogleBillingUtil.getInstance()
.addOnGoogleBillingListener(this,OnGoogleBillingListener())
.build(this)
}
/**
* 使用了JAVA8特性,可以选择性实现自己想要的方法。
*/
private inner class OnGoogleBillingListener : GoogleBillingUtil.OnGoogleBillingListener(){
//内购服务初始化成功
override fun onSetupSuccess() {
}
}
override fun onDestroy() {
super.onDestroy()
googleBillingUtil.onDestroy(this)
}
```
- 发起内购或者订阅
```java
public void queryInventoryInApp() //查询内购商品信息列表
public void queryInventorySubs() //查询订阅商品信息列表
public void purchaseInApp(Activity activity,String skuId) //发起内购
public void purchaseSubs(Activity activity,String skuId) //发起订阅
public List queryPurchasesInApp(Activity activity)//获取有效内购订单
public List queryPurchasesSubs(Activity activity)//获取有效订阅订单
public void queryPurchaseHistoryAsyncInApp(Activity activity)//查询历史内购订单
public void queryPurchaseHistoryAsyncSubs(Activity activity)//查询历史订阅订单
```
---
### =================响应码汇总([官方地址](https://developer.android.com/google/play/billing/billing_reference))=================
| 响应代码 | 值 | 说明 |
| ------------------------------------------- | -- | ------------------------------------------------------------------------------------------------------------------------------------ |
| BILLING_RESPONSE_RESULT_OK | 0 | 成功 |
| BILLING_RESPONSE_RESULT_USER_CANCELED | 1 | 用户按上一步或取消对话框 |
| BILLING_RESPONSE_RESULT_SERVICE_UNAVAILABLE | 2 | 网络连接断开 |
| BILLING_RESPONSE_RESULT_BILLING_UNAVAILABLE | 3 | 所请求的类型不支持 Billing API 版本(支付环境问题) |
| BILLING_RESPONSE_RESULT_ITEM_UNAVAILABLE | 4 | 请求的商品已不再出售。 |
| BILLING_RESPONSE_RESULT_DEVELOPER_ERROR | 5 | 提供给 API 的参数无效。此错误也可能说明未在 Google Play 中针对应用内购买结算正确签署或设置应用,或者应用在其清单中不具备所需的权限。 |
| BILLING_RESPONSE_RESULT_ERROR | 6 | API 操作期间出现严重错误 |
| BILLING_RESPONSE_RESULT_ITEM_ALREADY_OWNED | 7 | 未能购买,因为已经拥有此商品 |
| BILLING_RESPONSE_RESULT_ITEM_NOT_OWNED | 8 | 未能消费,因为尚未拥有此商品
---
### =================常见问题=================
**1. 初始化失败,错误码:3,这是支付环境问题。**
有以下可能:用的是模拟器,三件套版本太旧,应用的支付环境没配置(接入谷歌服务,支付权限),vpn地域不支持。
解决方法:a.先验证环境。在商店下载一个有内购的应用,看能否进行内购。b.如果别人的能进行内购之后,再次测试你的应用,看是否正常,来确认应用的支付环境是否正常。
**2. 能够查询价格,但无法购买,提示"商品无法购买"之类。**
这是基础配置问题,有以下可能:版本号与线上版本不对应,测试版本却不是测试账号(大概率),签名不对应。
**3. 能够查询价格,但无法调起支付都没有弹窗,错误码:3,报错:Error:In-app billing error: Null data in IAB activity resul。**
原因是没有给Google play商店弹窗权限,国内很多手机都有弹窗权限管理,特别是小米,如果没允许,是不会有任何提示,并且拦截了的。(这个问题在新版的gp商店已经不存在)
**4. 支付提示成功,但却走onQueryFail回调,并且返回的商品列表为null。**
这是因为你调错了方法,记得purchaseInApp是内购的,purchaseSubs是订阅的。查询的时候同理。另外查询的时候报错,很有可能是你setSKUS的时候传了一个空字符串,而不是空数组。
**5. 查询的时候返回的商品列表长度为0。**
setSkus的时候将内购sku和订阅sku的参数顺序弄错了,应该是第一个是内购的,第二个参数是订阅的。
或者是商品还没有发布成功,需要等待一段时间(很有可能,新发布的商品是无论怎么查询还是购买,谷歌那边都是没有响应的)
**6. 我们检测到您的应用使用的是旧版 Google Play Developer API。自 2019 年 12 月 1 日起,
我们将不再支持此 API 的版本 1 和版本 2。请在该日期之前将您使用的 API 更新到版本 3。请注意,此变动与弃用 AIDL/结算库无关。**
升级到com.android.billingclient:billing库,弃用AIDL相关代码。
后台也要弃用v3的校验接口。具体见谷歌官方文档。
---
### =================API说明=================
1. 初始化google应用内购买服务
```java
//设置内购id和订阅id,用于自动查询等
public static void setSkus(@Nullable String[] inAppSKUS,@Nullable String[] subsSKUS)
//获取单例,全局通用
public static GoogleBillingUtil getInstance()
//初始化服务,建立连接,全局通用
public GoogleBillingUtil build
//建立连接,build中已经包含,用于特殊用户自定义重连机制
public boolean startConnection(Activity activity)
```
2. 查询商品
```
//查询内购商品信息(价格等信息)
public void queryInventoryInApp(Activity activity)
//查询订阅商品信息(价格等信息)
public void queryInventorySubs(Activity activity)
```
3. 购买商品
```
//发起内购
public void purchaseInApp(Activity activity, String skuId)
//发起订阅
public void purchaseSubs(Activity activity,String skuId)
```
4. 消耗商品
```
//消耗商品,通过purchaseToken
public void consumeAsync(Activity activity,String purchaseToken)
//消耗商品,通过sku数组
public void consumeAsyncInApp(Activity activity,@NonNull String... sku)
//消耗商品,通过sku列表
public void consumeAsyncInApp(Activity activity,@NonNull List skuList)
```
5. 本地订单查询(查询GP本地缓存,不具备高实时性)
```
//取已经内购的商品
public List queryPurchasesInApp(Activity activity)
//获取已经订阅的商品
public List queryPurchasesSubs(Activity activity)
```
6. 在线订单查询(联网存,具备高实时性,但查到的是所有订单)
```
//异步联网查询所有的内购历史-无论是过期的、取消、等等的订单
public void queryPurchaseHistoryAsyncInApp(Activity activity)
//异步联网查询所有的订阅历史-无论是过期的、取消、等等的订单
public void queryPurchaseHistoryAsyncSubs(Activity activity)
```
7. 工具集合
```
//获取有效订阅的数量
public int getPurchasesSizeSubs(Activity activity)
//通过sku获取内购商品序号
public int getInAppPositionBySku(String sku)
//通过sku获取订阅商品序号
public int getSubsPositionBySku(String sku)
//通过序号获取订阅sku
public String getSubsSkuByPosition(int position)
//通过序号获取内购sku
public String getInAppSkuByPosition(int position)
//通过sku获取商品类型
public String getSkuType(String sku)
```
8. 其他方法
```
//google内购服务是否已经准备好
public static boolean isReady()
//设置是否自动消耗内购商品
public static void setIsAutoConsumeAsync(boolean isAutoConsumeAsync)
//断开连接google服务(不要频繁使用)
public static void endConnection()
```
9. 监听器相关
```
//添加监听器
public GoogleBillingUtil addOnGoogleBillingListener(Activity activity,OnGoogleBillingListener onGoogleBillingListener)
//移除监听器
public void removeOnGoogleBillingListener(OnGoogleBillingListener onGoogleBillingListener)
//移除某个页面的所有监听器
public void removeOnGoogleBillingListener(Activity activity)
//清除内购监听器,防止内存泄漏-在Activity-onDestroy里面调用。
public void onDestroy(Activity activity)
```