前言
有些基于 Gradle 构建的项目需要发布中央仓库,发布操作需要配置中央仓库的账号密码等敏感信息。
如果是在开源项目或其他不便于公开的场景,敏感信息不适合直接写死在 gradle.build 文件内。
解决方案
通过 gradle.properties 引入
敏感信息可以在 gradle.properties 文件中定义。
例如,我们在 gradle.properties 中定义了以下内容:
NEXUS_USERNAME=my_username
NEXUS_PASSWORD=my_password
写法一:直接引入属性(不推荐)
以下方式可以引入定义的属性:
credentials {
username NEXUS_USERNAME
password NEXUS_PASSWORD
}
但是,以上方式存在一定问题。
NEXUS_USERNAME, NEXUS_PASSWORD 等属性的值是敏感数据,被定义在特定环境(例如:作者自己的电脑中)的文件中,当其他环境没有定义该属性,则会出现 unknown property 的错误,导致项目无法构建:
A problem occurred evaluating root project 'camel-rocketmq'.
> Could not get unknown property 'NEXUS_USERNAME' for Credentials [username: null] of type org.gradle.internal.credentials.DefaultPasswo

本文介绍在Gradle项目中管理敏感信息的三种方法:通过gradle.properties、project.properties及环境变量引入账号密码等,避免硬编码,确保不同环境下项目的顺利构建。
最低0.47元/天 解锁文章
1865

被折叠的 条评论
为什么被折叠?



