QQ交流群(425219113)
免责声明
在使用BillingEasy前,请您务必仔细阅读并透彻理解本声明。您可以选择不使用本程序,但如果您使用了本程序或任何本程序未来的更新,您的使用行为将被视为对以下全部内容的认可。
您可享有法律规定下本程序不得排除或限制的担保、条件和条款。 除了这些不可排除的担保、条件和条款,本程序不作出任何担保、条件、陈述、保证或条款(无论是明示的还是暗示的,也无论是依据成文法、普通法、惯例、常例,还是其他任何原因), 包括但不限于性能、结果、安全、不侵权、适销性、完整性、可不受干扰使用、质量满意以及适用于任何特殊用途。
- 该库免费开源,使用该库请遵循Apache License2.0协议。
- 该库可能存在一定的bug风险以及网络服务中的风险,请在使用过程中经过严格测试,您需要了解并同意,因使用本程序而导致的任何损失,本程序不承担任何责任。
- 禁止将该库用于法律不允许的场景,该库不对任何使用行为负任何法律责任。
- 如该协议有更新,我们将直接更新此文本,您可以定期来看。但我们没有义务和责任确保您一定了解到更新的内容,但只要您继续使用该程序,就视为您同意本协议的所有内容。
一款全新设计的内购聚合,同时支持华为内购与谷歌内购。
- 使用了模块化技术,可以实现按需切换平台,而不残留任何平台代码。
- 重新设计了所有接口,去除了业务相关逻辑,还给大家原生操作。
- 运用了大量callback,提供更加便捷的即用即回API。
谷歌内购提醒(官方文档地址)
- 从 2023 年 8 月 2 日起,所有新应用都必须使用结算库版本 5 或更高版本。自 2023 年 11 月 1 日起,现有应用的所有新版本都必须使用结算库版本 5 或更高版本。了解详情。
- 如果您的应用以 Android 14 或更高版本为目标平台,您必须更新到 PBL 5.2.1 或 PBL 6.0.1 或更高版本。
allprojects {
repositories {
google()
mavenCentral()
jcenter()
maven {//私人仓库
credentials {
username '64902788b97ac8ef224e6817'
password '99F9lqriqO4R'
}
url 'https://packages.aliyun.com/maven/repository/2254835-release-ZGwQoJ/'
}
maven {url 'https://developer.huawei.com/repo/'}//华为用到
}
}
android{
//支持JAVA8,享受更多的语法糖
compileOptions {
sourceCompatibility JavaVersion.VERSION_1_8
targetCompatibility JavaVersion.VERSION_1_8
}
}
dependencies {
//主SDK
implementation 'com.TJHello.easy:BillingEasy:2.0.4-t01'//BillingEasy
//谷歌内购适配器(按需选择版本)
implementation 'com.TJHello.publicLib.billing:google:5.1.0.204'//(推荐)Google内购(按需添加)
implementation 'com.TJHello.publicLib.billing:google:6.0.1.204-t01'//(最新)Google内购(按需添加)
implementation 'com.TJHello.publicLib.billing:google:4.0.0.204-t07'//(谷歌方面即将强制报废)Google内购(按需添加)
//谷歌和华为适配器不可同时接入
//接入华为支付需要先接入HMS,详情看官方接入文档(https://developer.huawei.com/consumer/cn/doc/development/HMSCore-Guides/dev-process-0000001050033070)
implementation 'com.TJHello.publicLib.billing:huawei:6.4.0.301.204-t09'//(推荐)Huawei内购(按需添加)(暂不支持多activity)
implementation 'com.TJHello.publicLib.billing:huawei:5.1.0.300.204-t13'//Huawei内购(按需添加)(暂不支持多activity)
}
-
Step3 代码示例(MainActivity)
public class MainActivity extends AppCompatActivity {
private final MyBillingEasyListener billingEasyListener = new MyBillingEasyListener();
@Override
protected void onCreate(Bundle savedInstanceState) {
BillingEasy.setDebug(true);
BillingEasy.addProductConfig(ProductType.TYPE_INAPP_CONSUMABLE,"可消耗商品code","可消耗商品code");
BillingEasy.addProductConfig(ProductType.TYPE_INAPP_NON_CONSUMABLE,"非消耗商品code","非消耗商品code");
BillingEasy.addProductConfig(ProductType.TYPE_SUBS,"订阅商品code","订阅商品code");
ProductConfig productConfig = ProductConfig.build(ProductType.TYPE_INAPP_NON_CONSUMABLE,"test_code","noads");//添加一个带去广告属性的商品
BillingEasy.addProductConfig(productConfig);
BillingEasy.addListener(billingEasyListener);//添加完整监听器
BillingEasy.init(this);
//查询商品信息-两种用法
BillingEasy.queryProduct(ProductType.TYPE_INAPP_CONSUMABLE);
BillingEasy.queryProduct(ProductType.TYPE_INAPP_CONSUMABLE,(billingEasyResult, productInfoList) -> {
});
//发起购买
BillingEasy.purchase(this,"商品code");
}
//仅华为内购需要调用
@Override
protected void onActivityResult(int requestCode, int resultCode, @Nullable Intent data) {
BillingEasy.onActivityResult(requestCode,resultCode,data);
}
@Override
protected void onDestroy() {
//多activity情况下注意移除监听器,避免内存泄漏
BillingEasy.removeListener(billingEasyListener);
super.onDestroy();
}
//以下接口只要支持了JAVA8,都是可选实现
private class MyBillingEasyListener implements BillingEasyListener{
@Override
public void onConnection(@NonNull BillingEasyResult result) {
//内购服务连接
}
@Override
public void onDisconnected() {
//内购服务断开
}
@Override
public void onQueryProduct(@NonNull BillingEasyResult result, @NonNull List<ProductInfo> productInfoList) {
//查询商品信息
}
@Override
public void onPurchases(@NonNull BillingEasyResult result, @NonNull List<PurchaseInfo> purchaseInfoList) {
//如已开启自动消耗与购买,则不需要手动消耗与确认购买
//购买商品,判断示例
if(result.isSuccess){
for (PurchaseInfo purchaseInfo : purchaseInfoList) {
//判断商品是否有效
if(purchaseInfo.isValid()){
for (ProductConfig productConfig : purchaseInfo.getProductList()) {
//判断商品类型
String type = productConfig.getType();
if(type!=null){
switch (type){
//内购商品-可消耗
case ProductType.TYPE_INAPP_CONSUMABLE:{
//消耗商品(消耗包括确认购买)
BillingEasy.consume(purchaseInfo.getPurchaseToken());
}break;
//内购商品-非消耗||订阅商品
case ProductType.TYPE_INAPP_NON_CONSUMABLE:
case ProductType.TYPE_SUBS: {
//判断是否已经确认购买
if(!purchaseInfo.isAcknowledged()){
//确认购买
BillingEasy.acknowledge(purchaseInfo.getPurchaseToken());
}
}break;
}
}
// //或者
// if(productConfig.canConsume()){
// //消耗商品
// BillingEasy.consume(purchaseInfo.getPurchaseToken());
// }else{
// //确认购买
// if(!purchaseInfo.isAcknowledged()){
// BillingEasy.acknowledge(purchaseInfo.getPurchaseToken());
// }
// }
}
}
}
}
}
@Override
public void onQueryOrder(@NonNull BillingEasyResult result,@NonNull String type, @NonNull List<PurchaseInfo> purchaseInfoList) {
//查询有效订单(补单逻辑可以在此实现)
}
@Override
public void onQueryOrderHistory(@NonNull BillingEasyResult result,@NonNull String type, @NonNull List<PurchaseHistoryInfo> purchaseInfoList) {
//查询历史订单
}
}
}
//添加一个商品信息(必须)
BillingEasy.addProductConfig( ProductType.TYPE_INAPP_CONSUMABLE,"商品code","商品code");
//查询商品信息
BillingEasy.queryProduct();
BillingEasy.queryProduct((billingEasyResult, productInfoList) -> {
});
//发起购买
BillingEasy.purchase(activity,"商品code");
BillingEasy.purchase(activity,param);
//查询订单信息
BillingEasy.queryOrderAsync();//联网查询有效订单
BillingEasy.queryOrderLocal();//查询本地缓存订单
BillingEasy.queryOrderHistory();//查询历史订单
//消耗商品
BillingEasy.consume("purchaseToken");
//确认购买
BillingEasy.acknowledge("purchaseToken");
-
谷歌内购3.0.2以及以上版本要求谷歌商店的版本在:25.8.21以上,已知21.24.18无法购买,升级谷歌商店可到apkpure。
-
reqCode:4,reqMsg:,请检查游戏状态是否正常,检查是否已经添加了测试账号与检查是否加入内测。
2.0.3-t13 2023/03/15 【测试版】
1、修复华为支付的若干问题
2、修复谷歌支付若干问题
2.0.3-t06 2023/01/05 【测试版】
1、修复华为支付的若干问题
2、更换仓库地址
2.0.3-t03 2023/01/05 【测试版】
1、增加未初始化的情况的判断,避免在极端情况下的空指针问题
2、补漏个别字段,修复个别接口type不对应的问题
2.0.3-t01 2022/09/21 【测试版】
1、支持谷歌内购5.0.0版本
2、个别接口与监听器做了修改
2.0.2-t01 2022/04/29 【测试版】
1、删除purchase方法的callback用法。
2、purchase方法添加PurchaseParam参数,支持高级用法需要的参数传递
2.0.1-t01 2022/04/28 【测试版】
1、该版本支持了华为内购,API略微改动
2、优化了使用体验
0.1.2 2022/01/27
1、queryOrderLocal与queryOrderHistory不生效的问题
2、移除自动查询订单功能,需要查询订单则自行调用queryOrder系列方法
0.1.2-a02 2021/12/8
1、修复个别时候在购买成功回调里无法获得商品详情的问题。
0.1.2-a01 2021/11/26
1、删除原有的BillingEasy做法,将BillingEasyStatic改名为BillingEasy,采用全静态操作的做法。
0.1.1-t14 2021/11/23
1、PurchaseInfo增加getProductInfo方法,可方便获取商品信息。
0.1.1-t13 2021/10/27
1、修复自动消耗与自动确认购买的逻辑开关无效的问题
2、修复googleSkuDetails.type没有值的问题
0.1.1-t12 2021/10/15
1、添加发起购买的时候,因获取商品信息失败而导致的错误回调
0.1.1-t11 2021/09/25
1、添加自动消耗与自动确认购买的逻辑,默认关闭。
0.1.1-t10 2021/09/16
1、修复-商品配置信息无法全局动态添加引发的系列的问题。
2、增加-初始化添加链接内购服务器成功的回调
0.1.1-t09 2021/09/08
1、添加BillingEasyStatic类,全静态操作
2、去除BillingEasy和BillingManager的免混淆规则
0.1.1-t08 2021/08/25(存在bug,已删除)
1、添加商品配置自动去重功能
2、添加cleanProductConfig接口,清除所有商品配置
0.1.1-t07 2021/08/02
1.修复购买成功接口会多重复回调一次的bug。
0.1.1-t06
1.优化商品详情的查询逻辑,避免多余的结果回调。
0.1.1-t05
1.修复消耗商品没有传入callback会导致空指针报错的问题。