签名配置
最后更新于:2022-04-01 02:25:01
# 签名配置
签名一个应用程序需要以下文件:
- keystore
- keystore密码
- key的别名(alias)
- key密码
- 存储类型
位置,key 名,两个密码和存储类型一起组成了这个签名配置(*SigningConfig*)
默认情况下,**debug** 被配置成使用 debug keystore,debug keystore 使用默认的密码和默认 key 及默认的 key 密码。
debug keystore 的位于 `$HOME/.android/debug.keystore`,如果文件不存在,则会自动创建。
**debug***Build Type*(构建类型)会自动使用 **debug** 的 *SigningConfig*(签名配置)。
可以通过 **signingConfigs** DSL 容器来创建其他配置或者自定义内建的默认配置:
~~~
android {
signingConfigs {
debug {
storeFile file("debug.keystore")
}
myConfig {
storeFile file("other.keystore")
storePassword "android"
keyAlias "androiddebugkey"
keyPassword "android"
}
}
buildTypes {
foo {
debuggable true
jniDebuggable true
signingConfig signingConfigs.myConfig
}
}
}
~~~
以上代码片段修改了 debug keystore 的路径到项目的根目录下。在这个例子中,这将影响其他用到 **debug** 构建类型的构建类型。
这里也创建了一个新的 *Single Config*(签名配置)和一个使用这个新签名配置的新的 *Build Type*(构建类型)。
> 注意:只有默认路径下的 debug keystore 不存在时才会自动创建。改变 debug keystore 的路径并不会在新路径下自动创建 debug keystore。如果创建不同名的 SigningConfig,并使用默认的 debug keystore 路径,那么还是会在默认路径下创建 debug keystore。换句话说,会不会自动创建是根据 keystore 的路径来判断,而不是配置的名称。
> 注意:虽然经常使用项目根目录的相对路径作为 keystore 的路径,但是也可以使用绝对路径,尽管这并不推荐(除了自动创建出来的 debug keystore)
> **注意:如果将这些文件添加到版本控制,你可能不希望将密码直接写到这些文件。下面的 `Stack Overflow` 链接提供从控制台或者环境变量中获取密码的方法:**[http://stackoverflow.com/questions/18328730/how-to-create-a-release-signed-apk-file-using-gradle](http://stackoverflow.com/questions/18328730/how-to-create-a-release-signed-apk-file-using-gradle)**我们以后还会在这个指南中添加更多的详细信息。**