问题描述
我在打多渠道包的时候,我需要区分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'
1
2
3
*Whatwentwrong:
Executionfailedfortask':app:processDebugAGCPlugin'.
>ERROR:FailedtoverifyAGConnect-Config'/client/package_name',expected:'com.gxx.fast',butwas:'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"
1
2
3
4
//测试环境
"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;
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
defisUseReleaseAppPackageName=false是否使用正式环境的包名
android{
signingConfigs{
.....省略代码
}
defaultConfig{
.....省略代码
}
buildTypes{
debug{
.....省略代码
}
release{
.....省略代码
}
//复制文件
taskcopyAgconnecToRelease(type:Copy){
//print"你好世界"
from"src/pushservices/release/"
include"agconnect-services.json"
into"./"
}
//复制文件
taskcopyAgconnecToDebug(type:Copy){
from"src/pushservices/debug/"
include"agconnect-services.json"
into"./"
}
afterEvaluate{
defisDebugBuiildTypes=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模式
defisReleaseBuildType(){
booleanisReleaseTypes=false;
for(Strings:gradle.startParameter.taskNames){
if(s.equals(":app:assembleRelease")){
isReleaseTypes=true;
break;
}
}
returnisReleaseTypes;
}
上面的代码写完后,我们直接运行或者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 "./"
}
1
2
3
4
5
6
taskcopyAgconnecToRelease(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 手动设置参数
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
taskswitchTvvvv(type:Copy){
print"你好"
}
classHelloGxxTaskextendsDefaultTask{
Stringmessage='This is RygTask'
//@TaskAction表示该Task要执行的动作,即在调用该Task时,hello()方法将被执行
@TaskAction
defhello(){
println"Hello world. $message"
}
}
//hello使用了默认的message值
taskhello(type:HelloGxxTask)
//重新设置了message的值
taskhello1(type:HelloGxxTask){
message="I am an android developer"//类似fromincludeinto手动设置参数
}
自定义task.jpg
所以from include into 都是AbstractCopyTask 里面的方法,所以他们是在执行阶段执行
参考链接