我最近读到在 bash 脚本中使用不带引号的参数很危险。我知道当涉及到 SQL 查询时,转义是至关重要的,但我没有看到以下代码有任何问题(除了明显的目录遍历)
#!/bin/bash
MYDIR="/tmp/$1"
if [ -d $MYDIR ] ; then
/bin/rmdir $MYDIR
fi
分配行中的引号是否已经足够?
似乎唯一可能的是“如果”行说
# ./mm.sh "arg1 arg2"
./mm.sh: line 5: [: /tmp: binary operator expected
但这对我来说似乎不是很危险。有什么我错过的吗?
编辑:更具体地说。当我使用它运行它时,有什么方法可以提升我的权限sudo mm.sh
吗?
问候,
卢卡斯