博客更新 2020-05-20
debug/release 修改包名晴叨,取不同包名下的agconnect-services.json 文件 V2 解決每次更換包名涂召,都是要手動(dòng)刪除agconnect-services.json文件操作
問題描述
我在打多渠道包的時(shí)候舟陆,我需要區(qū)分debug版本误澳,release版本,其中涉及到包名的不同秦躯,我使用release編譯的時(shí)候忆谓,發(fā)現(xiàn)如下錯(cuò)誤信息。這個(gè)原因是因?yàn)槟愕腶gconnect-services文件里面含有一個(gè) package_name 參數(shù)踱承,這個(gè)參數(shù)是需要指定包名的陪毡,如果 package_name 填寫的報(bào)名米母,和目前你所使用的包名沒有對(duì)應(yīng)上就會(huì)出現(xiàn)這樣的錯(cuò)誤
修改過程中遇到的錯(cuò)誤信息
* 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'
不是很完美的解決問題
既然是需要區(qū)分包名的,我不如直接copy 2份出來毡琉,放到src下面,并新建一個(gè)類 pushservices 里面存放 debug/release 的類并存放 agconnect-services.json文件妙色,這樣我們想使用哪個(gè)版本的桅滋,就使用哪個(gè)版本的
agconnect-services.json 記得里面修改
//測(cè)試環(huán)境
"package_name":"com.gxx.fast.debug"
//正式環(huán)境
"package_name":"com.gxx.fast"
打開你的app下面的build.gradle
def isUseReleaseAppPackageName = false 是否使用正式環(huán)境的包名
android {
signingConfigs {
.....省略代碼
}
defaultConfig {
.....省略代碼
}
buildTypes {
debug {
.....省略代碼
}
release {
.....省略代碼
}
//復(fù)制文件
task copyAgconnecToRelease(type:Copy){
// print "你好世界"
from "src/pushservices/release/"
include "agconnect-services.json"
into "./"
}
//復(fù)制文件
task copyAgconnecToDebug(type:Copy){
from "src/pushservices/debug/"
include "agconnect-services.json"
into "./"
}
afterEvaluate {
def isDebugBuiildTypes = false;//是否運(yùn)行的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模式下編譯環(huán)境
if (isUseReleaseAppPackageName ){ //使用正式環(huán)境包名
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;
}
上面的代碼寫完后身辨,我們直接運(yùn)行或者build一下丐谋,就會(huì)自動(dòng)從debug/release 拷貝一份agconnect-services.json 文件到根目錄路
注意
我們每次修改isUseReleaseAppPackageName 的值,都需要 刪除根目錄下的 agconnect-services.json
其它學(xué)習(xí)到的知識(shí)點(diǎn)
我們從上面copy一段代碼下來煌珊,如下
task copyAgconnecToRelease(type:Copy){
print "你好世界"
from "src/pushservices/release/"
include "agconnect-services.json"
into "./"
}
我們?cè)赽uild或者直接run的時(shí)候号俐,發(fā)現(xiàn) “你好世界” 會(huì)最先打印,那是不是就意味著定庵,from include into 也會(huì)默認(rèn)的執(zhí)行吏饿?其實(shí)不是的,print 是在配置階段構(gòu)建的蔬浙,所以不管執(zhí)行什么task都是最先執(zhí)行的猪落。 from, into, rename 都繼承自 Copy,所以即使直接寫也是在執(zhí)行階段執(zhí)行畴博,摘自十分鐘搞定 Gradle 笨忌。我感覺就類似如下這樣的代碼 部分摘自 全面理解Gradle - 定義Task
task switchTvvvv(type:Copy){
print "你好"
}
class HelloGxxTask extends DefaultTask{
String message = 'This is RygTask'
// @TaskAction 表示該Task要執(zhí)行的動(dòng)作,即在調(diào)用該Task時(shí),hello()方法將被執(zhí)行
@TaskAction
def hello(){
println "Hello world. $message"
}
}
// hello使用了默認(rèn)的message值
task hello(type:HelloGxxTask)
// 重新設(shè)置了message的值
task hello1(type:HelloGxxTask){
message ="I am an android developer" //類似from include into 手動(dòng)設(shè)置參數(shù)
}
所以from include into 都是AbstractCopyTask 里面的方法俱病,所以他們是在執(zhí)行階段執(zhí)行