Mar*_*nor 12
使用包含控制Nexus凭据的属性的设置文件:
<ivysettings>
<property name="repo.host" value="default.mycompany.com" override="false"/>
<property name="repo.realm" value="Sonatype Nexus Repository Manager" override="false"/>
<property name="repo.user" value="deployment" override="false"/>
<property name="repo.pass" value="deployment123" override="false"/>
<credentials host="${repo.host}" realm="${repo.realm}" username="${repo.user}" passwd="${repo.pass}"/>
..
..
</ivysettings>
Run Code Online (Sandbox Code Playgroud)
运行构建时,您可以指定真实的用户名和密码:
ant -Drepo.user=mark -Drepo.pass=s3Cret
Run Code Online (Sandbox Code Playgroud)
将密码存储为文件系统上的属性需要加密.
Jasypt有一个可以生成加密字符串的命令行程序:
$ encrypt.sh verbose=0 password=123 input=s3Cret
hXiMYkpsPY7j3aIh/2/vfQ==
Run Code Online (Sandbox Code Playgroud)
这可以保存在build的属性文件中:
username=bill
password=ENC(hXiMYkpsPY7j3aIh/2/vfQ==)
Run Code Online (Sandbox Code Playgroud)
以下ANT目标将解密任何加密的ANT属性:
<target name="decrypt">
<taskdef name="groovy" classname="org.codehaus.groovy.ant.Groovy" classpathref="build.path"/>
<groovy>
import org.jasypt.properties.EncryptableProperties
import org.jasypt.encryption.pbe.StandardPBEStringEncryptor
StandardPBEStringEncryptor encryptor = new StandardPBEStringEncryptor()
encryptor.setPassword(properties["master.pass"])
Properties props = new EncryptableProperties((Properties)properties, encryptor);
props.propertyNames().each {
properties[it] = props.getProperty(it)
}
</groovy>
</target>
Run Code Online (Sandbox Code Playgroud)
当然,为了使这项工作,需要将用于加密属性的密码指定为构建的一部分.
ant -Dmaster.pass=123
Run Code Online (Sandbox Code Playgroud)
这意味着该解决方案仅适用于隐藏静态数据.
为了我的目的,命令行凭据不是一个选项,因为我正在运行Jenkins并且它们被明确地粘贴在构建输出上,所以这是我的解决方案,通过合理安全来达到平衡.
在主目录中创建包含敏感信息的属性文件(我们称之为"maven.repo.properties")
repo.username=admin
repo.password=password
Run Code Online (Sandbox Code Playgroud)在构建文件的顶部附近,导入属性文件
<property file="${user.home}/maven.repo.properties"/>
Run Code Online (Sandbox Code Playgroud)在build.xml下的发布目标中,设置常春藤设置文件位置(确实已签入代码控制)但嵌入了凭据属性
<target name="publish">
<ivy:settings file="ivysettings.xml">
<credentials host="repohostname" realm="Artifactory Realm" username="${repo.username}" passwd="${repo.password}"/>
</ivy:settings>
<!-- ivy:makepom and ivy:publish targets go here -->
</target>
Run Code Online (Sandbox Code Playgroud)像以前一样创建你的ivysettings.xml,但删除username和passwd属性
然后,您可以利用操作系统的权限来确保除了您(或您的自动构建实现)之外的所有人都正确地隐藏了maven.repo.properties文件.