6

例如,假设我有一个脚本说:

#!/bin/bash
sudo setpci -s 00:02.0 F4.B=00

如何将 root 密码放入脚本中,以便它在读取和执行 sudo 行时接受它作为密码(所以我不必手动输入)?

4

1 回答 1

27

在您的 bash 脚本中产生一个期望会话通常是您自动化交互式提示的方式。

例如

expect -c "
spawn sudo setpci -s 00:02.0 F4.B=00
expect -nocase \"password:\" {send \"$PASS\r\"; interact}
"

请注意,在这种情况下,这不是推荐的方法,因为将 root 密码存储在 bash 脚本中是一个巨大的安全漏洞。

正确的解决方案是编辑您/etc/sudoers/以不提示您输入该二进制文件的密码。

#in /etc/sudoers
neohexane ALL=(ALL) NOPASSWD : /usr/bin/setpci
于 2012-05-15T18:49:10.923 回答