解决的应用场景
在通过ADB调试APP时,会自动根据不同的开发板自动加载不同的签名文件。
常规做法与分析
在不同方案共用一套APP代码的时候,需要用不同的签名文件,常规的做法是直接将签名文件写死,如:
signingConfigs {
release {
storeFile file("platform.jks")
storePassword '123456'
keyAlias 'platform1key'
keyPassword '123456'
}
}
对于追求自动化的人来说这做法太不理想了。那么有没有办法在Build阶段,自动区分不同开发板来编译打包呢?如何区分呢?
我的解决办法是通过adb获取系统属性来区分不同开发板。
adb shell getprop ro.product.name
具体操作步骤
以app模块下的build.gradle为例,
有两个签名文件:platform_imx6.jks和platform_imx8.jks
1。将两个签名文件放在app模块的文件夹目录下(与app下的build.gradle同目录)
2。为方便管理签名,在app目录创建了private.properties,包含了两个jks的密码和alias
IMX6_STORE_FILE=platform_imx6.jks
IMX6_STORE_PASSWORD=77777777
IMX6_KEY_ALIAS=imx6key
IMX6_KEY_PASSWORD=77777777
IMX8_STORE_FILE=platform_imx8.jks
IMX8_STORE_PASSWORD=88888888
IMX8_KEY_ALIAS=imx8key
IMX8_KEY_PASSWORD=88888888
3。编辑app模块的build.gradle
添加两个方法
def static getPlatform() {
def adbCommand = 'adb shell getprop ro.product.name'
Process process = adbCommand.execute()
// println "Success execute Command: ${adbCommand.toString().readLines()}"
process.in.eachLine { processing ->
println processing
if(processing.equals("sabresd_6dq")){
println "cjb ===>platform is IMX6"
return "1"
} else if(processing.equals("evk_8mm")){
println "cjb ===>platform is imx8"
return "2"
}
return null
}
}
def getSignKeyProp() {
Properties props = new Properties()
def propFile = file('private.properties')
props.load(new FileInputStream(propFile))
if (propFile.canRead()) {
def platformType = getPlatform()
if(platformType.equals("1")){
props['STORE_FILE'] = props['IMX6_STORE_FILE']
props['STORE_PASSWORD'] = props['IMX6_STORE_PASSWORD']
props['KEY_ALIAS'] = props['IMX6_KEY_ALIAS']
props['KEY_PASSWORD'] = props['IMX6_KEY_PASSWORD']
}else if(platformType.equals("2")){
props['STORE_FILE'] = props['IMX8_STORE_FILE']
props['STORE_PASSWORD'] = props['IMX8_STORE_PASSWORD']
props['KEY_ALIAS'] = props['IMX8_KEY_ALIAS']
props['KEY_PASSWORD'] = props['IMX8_KEY_PASSWORD']
}else{
println "[cjb] No key type matched for signing"
return null
}
println "[cjb] BUILD STORE_FILE:" + props['STORE_FILE'] + " STORE_PASSWORD:" + props['STORE_PASSWORD'] + " KEY_PASSWORD:" + props['KEY_PASSWORD'] + " KEY_ALIAS:" + props['KEY_ALIAS']
return props
}else {
println '*****RELEASE BUILD NOT FOUND SIGNING FILE*****'
android.buildTypes.release.signingConfig = null
return null
}
}
android {
//这里省略其他不相关配置
//......
signingConfigs {
Properties props = getSignKeyProp()
if (props != null) {
release {
storeFile file(props['STORE_FILE'])
storePassword props['STORE_PASSWORD']
keyAlias props['KEY_ALIAS']
keyPassword props['KEY_PASSWORD']
}
debug {
storeFile file(props['STORE_FILE'])
storePassword props['STORE_PASSWORD']
keyAlias props['KEY_ALIAS']
keyPassword props['KEY_PASSWORD']
}
}
}
}
说明:
getPlatform()通过ADB获取平台类型,这里的字符串"sabresd_6dq"和"evk_8mm"就是通过连接不同板子后通过adb shell getprop ro.product.name获取的。
getSignKeyProp() 通过获取不同平台方案来加载private.properties内的不同配置内容。
最后通过signingConfigs 配置签名信息即可。
补充:
其实通过getSignKeyProp()代码可知,在读取不到配置时,用的就是系统默认的debug签名了。
扩展思路
执行批量命令,如推送文件,删除设备上的某些旧数据,清除APP数据等等。
甚至,可以在dependencies { } 内通过判断特定条件来做条件依赖不同的库。