例如,假设我有一个脚本说:
#!/bin/bash
sudo setpci -s 00:02.0 F4.B=00
如何将 root 密码放入脚本中,以便它在读取和执行 sudo 行时接受它作为密码(所以我不必手动输入)?
在您的 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