签名配置
签名一个应用程序需要以下文件(查看 Signing Your Application 了解更多 APK 签名的知识):
- keystore 文件
- keystore 密码
- key alias
- key 密码
- 签名文件的类型
签名文件的路径、类型、key 名及一组密码构成了 SigningConfig。默认情况下,debug 使用 debug keystore,debug keystore 使用默认的 storePassword、keyAlias 及 keyPassword。
debug keystore 位于 $HOME/.android/debug.keystore
,如果文件不存在,则会自动创建。debug Build Type 默认使用 debug 的 SigningConfig。
可以通过 signingConfigs DSL 容器来创建其他配置或者自定义内建构建类型(debug、release)的默认配置:
android {
signingConfigs {
debug {
storeFile file("debug.keystore")
}
myConfig {
storeFile file("other.keystore")
storePassword "android"
keyAlias "androiddebugkey"
keyPassword "android"
}
}
buildTypes {
foo {
signingConfig signingConfigs.myConfig
}
}
}
以上代码片段指定了 debug keystore 的路径在项目根目录下。其他使用了相同配置的 Build Types 亦会受影响,在该例子中为 debug Build Type。该代码片段同时还创建了新的 Signing Config 及使用该签名配置的 Build Type。
注意:只有默认路径下的 debug keystore 不存在时才会自动创建。改变 debug keystore 的路径并不会在新路径下自动创建 debug keystore。如果创建新的 SigningConfig,并使用默认的 debug keystore 路径,那么 debug keystore 会自动创建。换句话说,会不会自动创建是根据 keystore 的路径来判断,而不是配置的名称。
注意:虽然我们经常用 keystore 的相对路径,但也可以用绝对路径,尽管这并不推荐(自动创建的 debug keystore 除外)
注意:如果将这些文件添加到版本控制,你可能不希望将密码直接写到这些文件。可查看 Stack Overflow post 了解如何从控制台或者环境变量中获取密码。