【发布时间】:2021-12-11 20:43:15
【问题描述】:
我想用公共和私有证书替换脚本模板中的变量。
例如,我使用以下命令生成了一个harbor.crt 公共证书和一个harbor.key 私钥:
sudo openssl req -x509 -newkey rsa:4096 -sha256 -days 3650 -nodes -keyout /data/harbor.key -out /data/harbor.crt -subj "/CN=$LOCAL_IP" -addext "subjectAltName=IP:127.0.0.1,IP:$LOCAL_IP"
在模板脚本中,我想用上述文件替换以下变量:
CFG_HARBOR_CRT="CRT" # Harbor registry certificate
CFG_HARBOR_KEY="KEY" # Harbor registry key
为了替换这些值,我尝试过这样做:
HARBOR_CRT=`sudo cat /data/harbor.crt`
HARBOR_KEY=`sudo cat /data/harbor.key`
sudo sed -i "s/CFG_HARBOR_CRT\=\"[^\"]*\"/CFG_HARBOR_CRT\=\"$HARBOR_CRT\"/g" ./template-script.sh
sudo sed -i "s/CFG_HARBOR_KEY\=\"[^\"]*\"/CFG_HARBOR_KEY\=\"$HARBOR_KEY\"/g" ./template-script.sh
但是两个命令都失败了:sed: -e expression #1, char 70: unterminated s' 命令`
有没有办法将sed 命令与未转义的变量一起使用?
【问题讨论】:
-
我认为您需要退后一步,描述您想要实现的什么,而不是如何。首先,将 PEM 编码证书中的一些 base64 数据粘贴到 shell 脚本中是没有意义的;数据不是有效的脚本。如果要将整个文件读入 shell 变量,只需正确引用它,例如
MY_CERT_DATA="$(< /file/with/pem_cert.crt)"。如果要将证书数据内联到脚本中,可以使用awk,正常打印不相关的脚本行并粘贴多行变量值:MY_CERT_DATA='-----BEGIN CERTIFICATE----- ... <lines with base64> ...'。 -
您的公共证书和私钥是多行字符串。您希望如何将它们插入到您的模板中?开始双引号之后和结束双引号之前的新行?其他?
-
我需要将证书写入 shell 脚本,因为它将被共享到另一台服务器。服务器 #1 在服务器 #2 上生成连接到 #1 所需的各种令牌和证书。
-
如果目标是将这些文件推送到另一台主机......为什么不看看
sftp/scp解决方案?或者,如果您想将这些文件“嵌入”到脚本中,并将所述脚本(sftp/scp?)复制到另一台主机,请考虑通过base64运行文件并将base64数据嵌入到脚本中,然后在另一端运行base64 -d以解密数据并存储在目标文件中;使用base64数据应该消除大多数(全部?)sed处理特殊字符和/或试图找到不在数据中的sed脚本分隔符的麻烦 -
谢谢@markp-fuso。那成功了。我使用
HARBOR_CRT=$(sudo cat /data/harbor.crt | base64 -w 0)将证书转换为B64 并使用echo $CFG_HARBOR_CRT | base64 --decode进行解码。您可以发布我会接受的答案:)