我使用set -o allexport; source .env; set +o allexport
从.env文件中导出所有变量。不幸的是,有一个变量包含)
,因此会导致语法错误。使用上面的命令可以解决这个问题吗?我知道可以在括号中设置它,但.env在某种程度上是自动生成的,没有括号。
例如,Dotenv看起来像这样:
username=test
password=*fdas_dfar+)mbn
发布于 2019-04-16 17:13:25
source .env
source
是一个外壳命令,.env
文件被解析为外壳文件。您需要引用字符串,就像在shell中一样。
username=test
password='*fdas_dfar+)mbn'
它的优点是,您可以从以下文件运行所有shell命令:
username=$(echo test)
password='*fdas_dfar+)mbn'
或者,您可以编写自己的解析器,例如:
while IFS='=' read -r name value; do
if [ -z "$value" -o -z "$name" ]; then
echo "Error - unparsable line!" >&2
exit 1
fi
# add quotes around `'`
value=$(<<<"$value" sed "s/'/'\''/g")
# set the variable value using bash special builtin
printf -v "$name" "%s" "$value"
done <.env
发布于 2019-04-17 03:45:46
如果您想要能够source .env
,那么它需要是有效的shell语法。这意味着引用包含外壳元数据的值,如)
。如果这是不可能的,因为文件还需要被其他不能处理引用的程序读取,那么您将需要一次读取并解析它。请不要按照旧答案中的建议使用eval
。eval
命令几乎总是导致的问题多于它解决的问题。与使用IFS技巧相比,我更喜欢这种方法,因为IFS本身就是危险的,应该始终在每个脚本的顶部将其设置为IFS=$'\n'
,并且不要在随后进行更改:
while read -r line
do
# Insert appropriate checks for malformed input or comments here.
key="${line%%=*}"
val="${line#*=}"
export "$key"="$val"
done < .env
但是,如果你知道输入是格式良好的,并且你喜欢危险的生活,那么这也很好用:
while IFS='=' read -r key val
do
export "$key"="$val"
done < .env
https://stackoverflow.com/questions/55703950
复制相似问题