我有一个脚本,自动需要访问密码保护系统的进程。通过一个接受用户密码作为参数的命令行程序访问系统。
我想提示用户输入密码,将其分配给一个shell变量,然后使用该变量构造访问程序的命令行(当然,这将产生我将处理的流输出)。
我在Bourne/Bash中是一个相当称职的shell程序员,但我不知道如何接受用户输入而不让它回显到终端(或者可能让它使用'*'字符回显)。
有人能帮忙吗?
我有一个脚本,自动需要访问密码保护系统的进程。通过一个接受用户密码作为参数的命令行程序访问系统。
我想提示用户输入密码,将其分配给一个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,然后再次打开。