我有一个脚本,自动需要访问密码保护系统的进程。通过一个接受用户密码作为参数的命令行程序访问系统。

我想提示用户输入密码,将其分配给一个shell变量,然后使用该变量构造访问程序的命令行(当然,这将产生我将处理的流输出)。

我在Bourne/Bash中是一个相当称职的shell程序员,但我不知道如何接受用户输入而不让它回显到终端(或者可能让它使用'*'字符回显)。

有人能帮忙吗?


当前回答

你也可以在不设置当前shell变量的情况下提示输入密码,如下所示:

$(read -s;echo $REPLY)

例如:

my-command --set password=$(read -sp "Password: ";echo $REPLY)

你可以用换行符添加这些提示值,这样做:

my-command --set user=$(read -sp "`echo $'\n '`User: ";echo $REPLY) --set password=$(read -sp "`echo $'\n '`Password: ";echo $REPLY)

其他回答

这里有另一种方法:

#!/bin/bash
# Read Password
echo -n Password: 
read -s password
echo
# Run Command
echo $password

read -s将为您关闭echo。只需将最后一行的echo替换为您想要运行的命令。

在一些shell(例如bash)中,read支持-p prompt-string,这将允许echo和read命令合并。

read -s -p "Password: " password

read的-s选项在POSIX标准中没有定义。见http://pubs.opengroup.org/onlinepubs/9699919799/utilities/read.html。我想要一些可以工作于任何POSIX shell的东西,所以我写了一个小函数,使用stty禁用echo。

#!/bin/sh

# Read secret string
read_secret()
{
    # Disable echo.
    stty -echo

    # Set up trap to ensure echo is enabled before exiting if the script
    # is terminated while echo is disabled.
    trap 'stty echo' EXIT

    # Read secret.
    read "$@"

    # Enable echo.
    stty echo
    trap - EXIT

    # Print a newline because the newline entered by the user after
    # entering the passcode is not echoed. This ensures that the
    # next line of output begins at a new line.
    echo
}

这个函数的行为与read命令非常相似。下面是read的简单用法,然后是类似的read_secret用法。read_secret的输入显示为空,因为它没有回显到终端。

[susam@cube ~]$ read a b c
foo \bar baz \qux
[susam@cube ~]$ echo a=$a b=$b c=$c
a=foo b=bar c=baz qux
[susam@cube ~]$ unset a b c
[susam@cube ~]$ read_secret a b c

[susam@cube ~]$ echo a=$a b=$b c=$c
a=foo b=bar c=baz qux
[susam@cube ~]$ unset a b c

下面是另一个使用-r选项来保留输入中的反斜杠。这是因为上面定义的read_secret函数将它接收到的所有参数传递给read命令。

[susam@cube ~]$ read -r a b c
foo \bar baz \qux
[susam@cube ~]$ echo a=$a b=$b c=$c
a=foo b=\bar c=baz \qux
[susam@cube ~]$ unset a b c
[susam@cube ~]$ read_secret -r a b c

[susam@cube ~]$ echo a=$a b=$b c=$c
a=foo b=\bar c=baz \qux
[susam@cube ~]$ unset a b c

最后,下面是一个示例,演示如何使用read_secret函数以符合POSIX的方式读取密码。

printf "Password: "
read_secret password
# Do something with $password here ...

这个链接有助于定义, *如何从使用中读取密码而不将其返回到终端 *如何用* -character替换每个字符。

https://www.tutorialkart.com/bash-shell-scripting/bash-read-username-and-password/

一个POSIX兼容的答案。注意使用/bin/sh而不是/bin/bash(它可以使用bash,但不需要bash。)

#!/bin/sh
stty -echo
printf "Password: "
read PASSWORD
stty echo
printf "\n"

使用stty关闭echo,然后再次打开。