2

我正在自动化以下过程:
通过 ssh 使用用户名“alpha”的密码“alpha”连接到名为“alpha”的系统。连接后,我想设置 root 密码(设置为“kickass”)。我连接的系统默认没有root密码。我编写了这个期望脚本来完成这项工作,但它不能始终如一地工作。它工作一次,然后如果我更改密码以再次测试,它会在发出“sudo passwd root”后等待“输入新的 UNIX 密码:”提示。有任何想法吗?

#!/usr/bin/expect -f
set arg1 [lindex $argv 0]
set force_conservative 1  ;# set to 1 to force conservative mode even if
              ;# script wasn't run conservatively originally
if {$force_conservative} {
    set send_slow {1 .1}
    proc send {ignore arg} {
        sleep .1
        exp_send -s -- $arg
    }
}

set timeout -1
spawn ssh alpha@$arg1
match_max 100000
expect -exact "password: "
send -- "alpha\r"
expect -exact "alpha@alpha:~\$ "
send -- "sudo passwd root\r"
expect -exact "password for alpha: "
send -- "alpha\r"
expect -exact "new UNIX password: "
send -- "kickass\r"
expect -exact "Retype new UNIX password: "
send -- "kickass\r"
expect -exact "alpha@alpha:~\$ "
send -- "exit\r"
expect eof

谢谢。

4

1 回答 1

2

扩展 Andrei Sfrent 的评论:

Sudo 通常具有某种超时值,因此如果您在超时期限内发出第二个 sudo 命令,就不会再次要求您输入密码。您可以将代码修改为以下内容:

send -- "sudo passwd root\r"
expect {
        -exact "password for alpha: "
            {
                send -- "alpha\r"
                exp_continue
            }

        -exact "new UNIX password: "
            {
                send -- "kickass\r"
            }
        }
于 2011-01-24T19:32:04.433 回答