Android Gradle 使用Task打包APK配置指定输出目录和文件名

想要实现的效果

  1. 通过运行Gradle的Task来执行打包操作,无需使用Android Studio的UI操作
  2. 指定APK文件的输出目录和文件名,需要包含:版本类型根项目名打包时间
  3. 证书不加入版本控制,密码等敏感信息不写入build.gradle

本例中:

  1. Gradle版本:8.7
  2. AGP版本:8.5.0

操作步骤

生成证书文件

本例中我们为debugrelease版本分别创建一个证书文件,密码均使用UUID生成,放在项目根目录下的jks目录中,该目录不加入版本控制 ,将其加入.gitignore并标记为排除目录

  1. Android Studio中点击菜单 Build-Generate Signed App Bundle/APK,直接选择下一步,点击Create New...
  2. Key store path为整数文件的保存路径,Password为证书文件密码,后续对应storePassword字段
  3. Key标签下的: Alias一般填debugreleasePassword为Alias密码,后续对应keyPassword字段
  4. 点击OK后文件就已生成好,原打包窗口直接取消退出

创建密码文件

jks目录中创建文件props.properties,内容如下:

properties 复制代码
DEBUG_FILE=/jks/debug.jks
DEBUG_KEY_ALIAS=debug
DEBUG_STORE_PASSWORD=f3e592cc-****-****-****-************
DEBUG_KEY_PASSWORD=dc29857c-****-****-****-************

RELEASE_FILE=/jks/release.jks
RELEASE_KEY_ALIAS=release
RELEASE_STORE_PASSWORD=7d5fa3e1-****-****-****-************
RELEASE_KEY_PASSWORD=d0535f98-****-****-****-************

这里分别配置了debugrelease版本的:证书路径,证书密码,Alias,Alias密码;具体值与上一步生成证书时填写的内容一致,后续build.gradle文件将从这里引用

build.gradle

修改子项目的build.gradle文件,加入如下内容,如果对应结构已存在,在其基础上增加,不要删除原内容:

groovy 复制代码
//引入密码文件
def props = new Properties()
props.load(new FileInputStream(rootProject.file("/jks/props.properties")))
// 按照指定格式生成打包时间
static def packageTime() {
    return new SimpleDateFormat("yyyy-MM-dd_HHmmss").format(new Date())
}

android {
    applicationVariants.configureEach { variant ->
        variant.outputs.configureEach { output ->
            // 指定打包目录
            variant.getPackageApplicationProvider().get().outputDirectory = rootProject.file("/apk/${buildType.name}")
            // 指定打包文件名
            outputFileName = "${rootProject.name}-${buildType.name}-${packageTime()}.apk"
        }
    }
    // 签名配置,引用密码文件内容
    signingConfigs {
        debug {
            storeFile rootProject.file(props['DEBUG_FILE'])
            keyAlias props['DEBUG_KEY_ALIAS']
            storePassword props['DEBUG_STORE_PASSWORD']
            keyPassword props['DEBUG_KEY_PASSWORD']

            v1SigningEnabled true
            v2SigningEnabled true
        }
        release {
            storeFile rootProject.file(props['RELEASE_FILE'])
            keyAlias props['RELEASE_KEY_ALIAS']
            storePassword props['RELEASE_STORE_PASSWORD']
            keyPassword props['RELEASE_KEY_PASSWORD']

            v1SigningEnabled true
            v2SigningEnabled true
        }
    }
    // 引用签名配置
     buildTypes {
        debug {
            signingConfig signingConfigs.debug
        }
        release {
            signingConfig signingConfigs.release
        }
    }
}

执行Task

默认情况下右侧的Gradle Task列表中只有一两个任务,我们需要的任务没有显示出来:

  1. 点击菜单File-Setting

  2. 左侧选择Experimental,勾选Configure all Gradle tasks during Gradle Sync,确认

  3. 随便修改一点build.gradle文件,点击弹出的提示执行同步操作,或者直接点击右上角工具栏的小象按钮执行同步,Task列表将生成完整的任务列表

  4. 在子项目的 Task-other折叠中即可看到assembleDebugassembleRelease任务,对应两个版本的打包操作

  5. 此时直接执行还会报一个警告(但不影响APK生成),可以在build.gradle末尾增加如下内容解决

    groovy 复制代码
    // 禁用任务 https://blog.csdn.net/ismartv_dagou2/article/details/127392262
    tasks.configureEach { task ->
        if (task.name.contains("ReleaseApkListingFileRedirect")) { // 过滤release
            task.enabled = false
        }
    }
相关推荐
拭心5 小时前
Google 提供的 Android 端上大模型组件:MediaPipe LLM 介绍
android
带电的小王7 小时前
WhisperKit: Android 端测试 Whisper -- Android手机(Qualcomm GPU)部署音频大模型
android·智能手机·whisper·qualcomm
梦想平凡8 小时前
PHP 微信棋牌开发全解析:高级教程
android·数据库·oracle
元争栈道8 小时前
webview和H5来实现的android短视频(短剧)音视频播放依赖控件
android·音视频
阿甘知识库9 小时前
宝塔面板跨服务器数据同步教程:双机备份零停机
android·运维·服务器·备份·同步·宝塔面板·建站
元争栈道9 小时前
webview+H5来实现的android短视频(短剧)音视频播放依赖控件资源
android·音视频
MuYe10 小时前
Android Hook - 动态加载so库
android
居居飒10 小时前
Android学习(四)-Kotlin编程语言-for循环
android·学习·kotlin
Henry_He13 小时前
桌面列表小部件不能点击的问题分析
android
工程师老罗13 小时前
Android笔试面试题AI答之Android基础(1)
android