如何在Maven的settings配置文件中对服务器密码进行加密?
创始人
2025-01-18 03:33:24
0

前情提要

在上篇文章中,我们详细的介绍了Maven配置文件settings.xml各个标签的含义以及配置方法(乾坤挪移大法——转移!),在讲解servers标签时,需要配置服务器的用户名和密码,有的同学就不想让自己的密码以明文形式暴露在settings文件中,怎么办呢?其实我们可以将加密后的密码写到settings配置文件中。

        my-server     my-username     {加密后的密码}     

这时候就会有同学提问了:加密之后服务器岂不是还要解密?而且这有啥用?密码不就是换了个皮囊??
哎呦还真不是这样的,听我慢慢道来。

双密码策略

在Maven中采用了双密码策略,有一个主密码以及一个服务器密码,这两个密码都是进行加密的,Maven会使用主密码去解密服务器密码,然后才能下载依赖包。主密码可以存储到其他文件中,当然也可以存储到U盘等移动介质中,这样只有得到U盘等移动介质的人才能访问私服。

第一步:生成主密码

  1. 在以管理员身份启动的cmd等终端中执行命令:mvn --encrypt-master-password ,其中是你的主密码,从Maven 3.2.1开始,不应使用参数,这样会使密码明文暴露在历史命令中,可以直接使用mvn --encrypt-master-password命令,然后敲下回车,会提示你输入主密码,加密完成后会返回加密后的密码,类似这样:{jSMOWnoPFgsHVpMvz5VrIt5kRbzGpI8u+9EF1iFQyJQ=}
  2. 这个密码应该存储在${user.home}/.m2/settings-security.xml中,或者是其他目录,存储形式如下,注意密码要加大括号,以便于Maven识别这是一个加密密码:
       {jSMOWnoPFgsHVpMvz5VrIt5kRbzGpI8u+9EF1iFQyJQ=}  

也可以使用下面的形式在${user.home}/.m2/settings-security.xml文件中指定主密码文件的位置:

   /Volumes/mySecureUsb/secure/settings-security.xml  

其中:/Volumes/mySecureUsb/secure/settings-security.xml是存有主密码的文件settings-security.xml的位置,这样就可以将存有主密码的文件settings-security.xml放到移动介质中,而settings文件完全可以分发给其他人,只有得到了移动介质的人才可以解密服务器密码从而访问私服。

第二步:加密服务器密码

  1. 使用以管理员身份启动的终端执行命令:mvn --encrypt-password ,同样的,可以直接使用mvn --encrypt-password命令,然后敲下回车,会提示你输入服务器密码,加密完成后会返回加密后的密码,类似这样:{COQLCE6DU6GtcS5P=}
  2. 将加密后的密码写入到settings配置文件中,注意密码要加大括号,以便于Maven识别这是一个加密密码:
 ...    ...            my.server       foo       {COQLCE6DU6GtcS5P=}      ...    ...  

小知识

如果加密后的密码存在{或者},如:jSMOWnoPFgsHVpMvz5VrIt5kRbzGpI8u+{EF1iFQyJQ=,这时候就需要对{}进行转义,转义后存入settings文件时是这样子的:{jSMOWnoPFgsHVpMvz5VrIt5kRbzGpI8u+\{EF1iFQyJQ=}
servers标签下也可以使用privateKeypassphrase标签指定私钥进行验证:

        my-ssh-server     your_username     /path/to/your/private_key     {mvn-encrypted}YourEncryptedPassphrase     
  • 元素指定了服务器的唯一标识符。
  • 元素指定了连接到服务器时使用的用户名。
  • 元素指定了私钥文件的路径。这可以是绝对路径或相对于用户主目录的路径。
  • 元素(可选)指定了加密的私钥密码,如果你的私钥有密码保护的话。

相关内容

热门资讯

有挂!德州私人局怎么透视,九游... 【福星临门,好运相随】;有挂!德州私人局怎么透视,九游破解版真的假的,解密教程(果然有挂);暗藏猫腻...
真的是有挂!we poker游... 真的是有挂!we poker游戏下,情怀透明器看手机纸牌,插件教程(一直真的是有挂);AI辅助机器人...
真的是有挂!hhpoker辅助... 真的是有挂!hhpoker辅助器视频,创思维辅助器,力荐教程(果然真的是有挂);创思维辅助器是一款益...
有挂!aapoker脚本,赣牌... 有挂!aapoker脚本,赣牌圈插件,解说技巧(原来有挂);赣牌圈插件软件透视开挂更新新赛季,主要更...
是有挂!wpk有那种辅助吗,哥... 是有挂!wpk有那种辅助吗,哥哥打大a辅助工具视频,存在挂教程(一贯是有挂);1、完成哥哥打大a辅助...
确实有挂!德扑之心免费透视,欢... 确实有挂!德扑之心免费透视,欢乐情怀辅助卦,规律教程(一贯确实有挂);欢乐情怀辅助卦是一项欢乐情怀辅...
是有挂的!佛手在线大菠萝辅助,... 是有挂的!佛手在线大菠萝辅助,免费宝宝浙江游戏安装,技巧教程(一直是有挂的);大家肯定在之前免费宝宝...
真的是有挂!来玩app 德州 ... 真的是有挂!来玩app 德州 辅助,同乡游辅助软件下载,靠谱教程(一贯真的是有挂);1.同乡游辅助软...
有挂!德州局透视脚本,宝宝浙江... 有挂!德州局透视脚本,宝宝浙江游戏有挂吗,存在挂教程(果然有挂);宝宝浙江游戏有挂吗软件透视开挂更新...
真的有挂!wepoker有透视... 真的有挂!wepoker有透视底牌吗,打哈儿小程序辅助,黑科技教程(其实真的有挂);最新版2026是...