debug/release 修改包名,取不同包名下的agconn

2020-05-12  本文已影响0人  一个冬季
博客更新 2020-05-20

debug/release 修改包名,取不同包名下的agconnect-services.json 文件 V2 解决每次更换包名,都是要手动删除agconnect-services.json文件操作

问题描述

我在打多渠道包的时候,我需要区分debug版本,release版本,其中涉及到包名的不同,我使用release编译的时候,发现如下错误信息。这个原因是因为你的agconnect-services文件里面含有一个 package_name 参数,这个参数是需要指定包名的,如果 package_name 填写的报名,和目前你所使用的包名没有对应上就会出现这样的错误

修改过程中遇到的错误信息
* What went wrong:
Execution failed for task ':app:processDebugAGCPlugin'.
> ERROR: Failed to verify AGConnect-Config '/client/package_name', expected: 'com.gxx.fast', but was: 'com.gxx.fast.debug'
不是很完美的解决问题

既然是需要区分包名的,我不如直接copy 2份出来,放到src下面,并新建一个类 pushservices 里面存放 debug/release 的类并存放 agconnect-services.json文件,这样我们想使用哪个版本的,就使用哪个版本的


存放agconnect-services.jpg

agconnect-services.json 记得里面修改

//测试环境
"package_name":"com.gxx.fast.debug"
//正式环境
"package_name":"com.gxx.fast"

打开你的app下面的build.gradle

def isUseReleaseAppPackageName = false 是否使用正式环境的包名
android {
    signingConfigs {
       .....省略代码
    }
    defaultConfig {
       .....省略代码
    }
    buildTypes {
        debug {
             .....省略代码
        }
        release {
             .....省略代码
    }
//复制文件
task copyAgconnecToRelease(type:Copy){
    //  print "你好世界" 
    from "src/pushservices/release/"
    include "agconnect-services.json"
    into "./"
}
//复制文件
task copyAgconnecToDebug(type:Copy){
    from "src/pushservices/debug/"
    include "agconnect-services.json"
    into "./"
}
afterEvaluate {
    def isDebugBuiildTypes = false;//是否运行的debug模式,false表示不是 true表示是
    if(isReleaseBuildType()){
        isDebugBuiildTypes = false;
    }else {
        isDebugBuiildTypes = true;
    }

    tasks.matching {
        it.name.equals("assembleDebug") || it.name.equals("assembleRelease")
    }.each {task->
        if(isDebugBuiildTypes){     //debug模式下编译环境
            if (isUseReleaseAppPackageName ){ //使用正式环境包名
                task.dependsOn(copyAgconnecToRelease);
            }else {
                task.dependsOn(copyAgconnecToDebug);
            }
        }else {
            task.dependsOn(copyAgconnecToRelease);
        }
    }
}

//判断是否为debug模式
def isReleaseBuildType(){
    boolean isReleaseTypes = false;
    for(String s : gradle.startParameter.taskNames) {
        if (s.equals(":app:assembleRelease")) {
            isReleaseTypes = true;
            break;
        }
    }
    return isReleaseTypes;
}

上面的代码写完后,我们直接运行或者build一下,就会自动从debug/release 拷贝一份agconnect-services.json 文件到根目录路
注意
我们每次修改isUseReleaseAppPackageName 的值,都需要 删除根目录下的 agconnect-services.json

其它学习到的知识点

我们从上面copy一段代码下来,如下

task copyAgconnecToRelease(type:Copy){
    print "你好世界" 
    from "src/pushservices/release/"
    include "agconnect-services.json"
    into "./"
}

我们在build或者直接run的时候,发现 “你好世界” 会最先打印,那是不是就意味着,from include into 也会默认的执行?其实不是的,print 是在配置阶段构建的,所以不管执行什么task都是最先执行的。 from, into, rename 都继承自 Copy,所以即使直接写也是在执行阶段执行,摘自十分钟搞定 Gradle 。我感觉就类似如下这样的代码 部分摘自 全面理解Gradle - 定义Task

task switchTvvvv(type:Copy){
    print "你好"
}

class HelloGxxTask extends DefaultTask{
    String message = 'This is RygTask'
    // @TaskAction 表示该Task要执行的动作,即在调用该Task时,hello()方法将被执行
    @TaskAction
    def hello(){
        println "Hello world. $message"
    }
}

// hello使用了默认的message值
task hello(type:HelloGxxTask)

// 重新设置了message的值
task hello1(type:HelloGxxTask){
    message ="I am an android developer"  //类似from  include   into  手动设置参数
}
自定义task.jpg

所以from include into 都是AbstractCopyTask 里面的方法,所以他们是在执行阶段执行

上一篇下一篇

猜你喜欢

热点阅读