0

这是我尝试执行命令的shell脚本sudo

#! /bin/sh

# Initialize values of arguments
SUDO_USER=""
SUDO_PWD=""
CMD_OR_SCRIPT=""

if ! options=$(getopt -u -o : -l sudoUser:,sudoPwd:,cmd: -- $@)
then
    echo "Wrong option given :: $1"
    exit 1
fi

set -- $options

while [ $# -gt 0 ]
do
    case $1 in
        --sudoUser)
                SUDO_USER="$2"
                shift
                ;;

        --sudoPwd)
                SUDO_PWD="$2"
                shift
                ;;

        --cmd)
                CMD_OR_SCRIPT="$2"
                shift
                ;;

    esac
    shift
done

if [ "$CMD_OR_SCRIPT" != "" ]; then
    if [ "$SUDO_USER" != "" ]; then
        if [ "$SUDO_PWD" != "" ]; then
            echo $SUDO_PWD | sudo -k -S -u $SUDO_USER $CMD_OR_SCRIPT
        else
            sudo -u $SUDO_USER -k -S $CMD_OR_SCRIPT
        fi
    else
        if [ "$SUDO_PWD" != "" ]; then
            echo $SUDO_PWD | sudo -k -S $CMD_OR_SCRIPT
        else
            sudo $CMD_OR_SCRIPT
        fi
    fi
fi

当我运行命令时-

./execSudoScript.sh --sudoUser root --sudoPwd pass --cmd ls

我按预期将当前目录的内容作为输出。但是,如果我将命令运行为-

./execSudoScript.sh --sudoUser root --sudoPwd pass --cmd ls /opt

我仍然获取当前目录的内容,而不是获取/opt. 是那之后的空间ls导致htis吗?我该如何解决?

4

1 回答 1

1

问题是您的脚本在--cmd. 这意味着您的命令中只能有一个令牌。

我建议您将所有位置参数作为运行命令,并将其传递给sudousing "$@"。为此,您需要避免像当前所做的那样转移所有非选项参数。

例如,您可以这样做:

while [ "$#" -gt 0 ]; do
    case "$1" in
    --sudoUser)
        SUDO_USER="$2"
        shift 2;;
    --sudoPwd)
        SUDO_PWD="$2"
        shift 2;;
    *)
        break;;
    esac
done

然后,对于脚本的其余部分,替换with的所有实例(需要双引号)。此外,在运行脚本时不要指定。因此,对于您的示例使用,您应该使用:$CMD_OR_SCRIPT"$@"--cmd

./execSudoScript.sh --sudoUser root --sudoPwd pass ls /opt

应 OP 的要求,这是整个脚本的编辑版本:

#!/bin/sh

# Initialize values of arguments
SUDO_USER=""
SUDO_PWD=""

while [ "$#" -gt 0 ]; do
  case "$1" in
  --sudoUser)
    SUDO_USER="$2"
    shift 2;;
  --sudoPwd)
    SUDO_PWD="$2"
    shift 2;;
  *)
    break;;
  esac
done

if [ -n "$SUDO_USER" ]; then
  if [ -n "$SUDO_PWD" ]; then
    echo "$SUDO_PWD" | sudo -k -S -u "$SUDO_USER" "$@"
  else
    sudo -u "$SUDO_USER" "$@"
  fi
else
  if [ -n "$SUDO_PWD" ]; then
    echo "$SUDO_PWD" | sudo -k -S "$@"
  else
    sudo "$@"
  fi
fi
于 2013-08-19T05:49:35.280 回答