当前位置:   article > 正文

修改Android打包apk的名字和目录_android studio gradle 配置生成apk文件名称

android studio gradle 配置生成apk文件名称

关键字

gradle配置变化、gradle kotlin版本、gradle新配置方式、签名、打包签名、仓库配置、仓库设置

定制apk位置的变化

app打包生成apk后通常需要进行备份,但是要区分好哪个apk是什么版本的、什么时候打包的,以方便以后区分使用。

最开始的想法是把版本号、创建时间这些加在apk文件名上即可,但是公司要求apk使用一个固定的名称,那我怎么保存版本号信息啊,后来想到可以加一个文件夹,在文件夹名字上加入这些信息即可,示例如一:

app/build.gradle

import java.text.SimpleDateFormat

android {
	//release版本输出位置与文件名配置
    applicationVariants.all { variant ->
        variant.outputs.all { output ->
            if (buildType.name == 'release') { //只处理生产版本
                def createTime = new Date().format("yyyy-MM-dd-kkmmss", TimeZone.getTimeZone("GMT+08:00"))
                def dirName = "ball_v${defaultConfig.versionName}_${defaultConfig.versionCode}_$createTime"
                def apkDir = rootProject.file("apk/$dirName")
                if (!apkDir.exists()) {
                    apkDir.mkdirs()
                }
                variant.packageApplicationProvider.get().outputDirectory = apkDir  // 指定apk的输出位置
                output.outputFileName = "Railway_4G_Platform_ball.apk"             // 指定输出文件名
            }
        }
    }
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19

这里省略了很多其它的信息,只贴关键代码,导包是要放在文件的最前面,关键代码要是写在android节点下的。

上面是以前的写法了,现在(今天是2024年03月07日)最新版本Android Studio已经使用了更新的Gradle,而且新创建的项目也默认使用Kotlin作为gradle的脚本语言了,那肯定是要追随官方的脚步啊,于是想把上面的配置翻译成Kotlin的版本,即可发现已经用不了,新版本的Gradle已经不允许那种方式来修改apk的名称了,于是又找了新的方式,感觉新的方式还更专业一些,如下:

import java.time.LocalDateTime
import java.time.format.DateTimeFormatter

android {    
    afterEvaluate {
        tasks.named("assembleRelease") {
            finalizedBy("copyAndRenameApkTask")
        }
    }
}

val copyAndRenameApkTask by tasks.registering(Copy::class) {
    val config = project.android.defaultConfig
    val versionName = config.versionName
    val versionCode = config.versionCode
    val formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd-HHmmss")
    val createTime = LocalDateTime.now().format(formatter)
    val destDir = File(rootDir, "apkBackup/big_data_v${versionName}_${versionCode}_$createTime")
    from("build/outputs/apk/release/app-release.apk")
    into(destDir)
    rename { _ -> "Railway_4G_Platform_big_data.apk" }
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22

与前面的修改方式对比:

  • 前面的是直接修改了打包apk的位置和apk的文件名。用的是groovy语言。
  • 后面的是打包后apk后复制该apk到指定的位置并进行重命名。用的是kotlin语言,平时写代码也是用Kotlin了,所以使用kotlin还是感觉比较亲切的。

打包两个版本的apk看一效果:
在这里插入图片描述
这样,我就完成了以公司要求的名字去命名apk,同时我使用文件夹名称来保留了apk的版本信息。

我们公司的apk在上传到公司服务器时,除了上传apk外,还需要填写apk的相关信息,比如包名、版本号这些,同时也允许通过上传一个配置文件来指定这些信息,像这样每次打包每次要修改这些信息也是挺烦人的,都说Gradle可以完成自动化的事情,于是让Gradle帮我生成一个不就行了吗,实现这个很简单,在之前的复制重命名的任务中添加生成配置文件的代码即可,如下:

val copyAndRenameApkTask by tasks.registering(Copy::class) {
    val config = project.android.defaultConfig
    val versionName = config.versionName
    val versionCode = config.versionCode
    val applicationId = config.applicationId
    val timeFormatter = DateTimeFormatter.ofPattern("yyyy-MM-dd-HHmmss")
    val dateFormatter = DateTimeFormatter.ofPattern("yyyy-MM-dd-HHmmss")
    val now = LocalDateTime.now()
	val createTime = now.format(timeFormatter)
	val createDate = now.format(dateFormatter)
    val destDir = File(rootDir, "apkBackup/big_data_v${versionName}_${versionCode}_$createTime")
    from("build/outputs/apk/release/app-release.apk")
    into(destDir)
    rename { _ -> "Railway_4G_Platform_big_data.apk" }
    doLast {
        File(destDir, "app上传配置.txt").outputStream().bufferedWriter().use {
            it
                .appendLine("版本号:${versionCode}")
                .appendLine("版本名称:${versionName}")
                .appendLine("软件名称:掌上运维")
                .appendLine("软件包名:${applicationId}")
                .appendLine("版本说明:说明")
                .appendLine("发布时间:${createDate}")
                .appendLine("发布状态:1")
                .appendLine("更新类型:0")    // 0-询问更新,1-强制更新到此版本
                .appendLine("强制更新标记:0") // 0-此版本无需强制更新,1-此版本不能使用,必须更新(此参数始终传0)
                .appendLine("软件分类:1")
                .appendLine("业务分类:1")
                .appendLine("软件级别:1")
                .append("备注:")
        }
    }
}
  • 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

效果如下:
在这里插入图片描述
app上传配置.txt内容如下:

版本号:20240307
版本名称:1.0.0
软件名称:掌上运维
软件包名:cn.dazhou.bluebook
版本说明:说明
发布时间:2024-03-07-154401
发布状态:1
更新类型:0
强制更新标记:0
软件分类:1
业务分类:1
软件级别:1
备注:
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13

另外,还可以把git的提交记录添加到文件夹中,以便可以清楚的知道打包的时候git的当时提交版本是什么,所以,在打包的时候一定要先把所有代码提交了再打包,核心代码如下:

import java.io.ByteArrayOutputStream

fun exec(command: String): String {
    val outputStream = ByteArrayOutputStream()
    val process = Runtime.getRuntime().exec(command)
    process.inputStream.copyTo(outputStream)
    return outputStream.toString().trim()
}

val copyAndRenameApkTask by tasks.registering(Copy::class) {
    。。。
    val gitHash = exec("git rev-parse --short HEAD")
    val destDir = File(rootDir, "apkBackup/big_data_v${versionName}_${versionCode}_${createTime}_$gitHash")
    。。。
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15

签名配置的变化

Kotlin版本:

android {
	signingConfigs {
		getByName("debug") {
            storeFile = file("123456.jks")
            storePassword = "123456"
            keyAlias = "key0"
            keyPassword = "123456"
        }
        create("release") {
            storeFile = file("123456.jks")
            storePassword = "123456"
            keyAlias = "key0"
            keyPassword = "123456"
        }
    }

    buildTypes {
    	debug {
            isMinifyEnabled = false
            proguardFiles(getDefaultProguardFile("proguard-android-optimize.txt"), "proguard-rules.pro")
            signingConfig = signingConfigs.getByName("debug")
        }
        release {
            isMinifyEnabled = false
            proguardFiles(getDefaultProguardFile("proguard-android-optimize.txt"), "proguard-rules.pro")
            signingConfig = signingConfigs.getByName("release")
        }
    }
}
  • 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

注意:这里signingConfigsdebug的配置要使用getByName,不能使用create,因为debug这个配置是默认就会创建的,如果你再创建就提示已经存在,所以只能用getByName。对比一下groovy语法旧的签名方式:

signingConfigs {
    config {
        keyAlias 'key0'
        keyPassword '123456'
        storeFile file('123456.jks')
        storePassword '123456'
    }
}
buildTypes {
    debug {
        signingConfig signingConfigs.config
        minifyEnabled false
        proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
    }
    release {
        signingConfig signingConfigs.config
        minifyEnabled false
        proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
    }
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20

如上代码,signingConfigs中我们创建了一个名为 “config”的签名配置,这个名字是可以随便取的,而且这个配置可以同时给debug的构建类型使用,也可以给release的构建类型使用。同理,在Kotlin的版本中,signingConfigs中的create()中的名字也可以随意取,同一个签名配置也可以同时给debug和release使用。

aar或jar包依赖的变化

在libs目录中添加jar或aar时的配置:

implementation(fileTree(mapOf("include" to arrayOf("*.jar", "*.aar"), "dir" to "libs")))
  • 1

对比原来Groovy的配置:

implementation(fileTree(includes: ["*.jar", "*.aar"], dir: "libs"))
  • 1

仓库设置的变化

maven {
    isAllowInsecureProtocol = true // 仓库默认不允许使用非https协议,所以这里设置为允许
    url = uri("http://192.168.1.251:8081/content/repositories/android_repositories/")
}
maven { url = uri("https://jitpack.io") }
  • 1
  • 2
  • 3
  • 4
  • 5

对比原来Groovy的配置:

 maven {
     allowInsecureProtocol = true // 仓库默认不允许使用非https协议,所以这里设置为允许
     url 'http://192.168.1.251:8081/content/repositories/android_repositories/'
 }
 maven { url 'https://jitpack.io' } // 用于:RxPermissions
  • 1
  • 2
  • 3
  • 4
  • 5
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Guff_9hys/article/detail/845361
推荐阅读
相关标签
  

闽ICP备14008679号