在 Linux 命令列指令碼中執行 sudo 時自動輸入密碼

YatHo發表於2017-04-10

使用 expect 實現自動登入的指令碼的原理。
  指令碼程式碼如下:
  ##############################################
  #!/usr/bin/expect
  set timeout 30
  spawn ssh -l username 192.168.1.1
  expect "password:"
  send "ispass\r"
  interact
  ##############################################
  1. [#!/usr/bin/expect]
  這一行告訴作業系統指令碼里的程式碼使用那一個 shell 來執行。這裡的 expect 其實和 linux 下的 bash、windows 下的 cmd 是一類東西。
  注意:這一行需要在指令碼的第一行。
  2. [set timeout 30]
  這是設定超時時間的,計時單位是:秒
  3. [spawn ssh -l username 192.168.1.1]
  spawn是進入expect環境後才可以執行的expect內部命令,如果沒有裝expect或者直接在預設的SHELL下執行是找不到spawn 命令的。所以不要用 “which spawn“之類的命令去找spawn命令。好比windows裡的dir就是一個內部命令,這個命令由shell自 帶,你無法找到一個dir.com 或 dir.exe 的可執行檔案。
  它主要的功能是給ssh執行程式加個殼,用來傳遞互動指令。
  4. [expect "password:"]
  這裡的expect也是expect的一個內部命令,有點暈吧,expect的shell命令和內部命令是一樣的,但不是一個功能,習慣就好了。這個 命令的意思是判斷上次輸出結果裡是否包含“password:”的字串,如果有則立即返回,否則就等待一段時間後返回,這裡等待時長就是前面設定的30 秒
  5. [send "ispass\r"]
  這裡就是執行互動動作,與手工輸入密碼的動作等效。
  溫馨提示: 命令字串結尾別忘記加上“\r”,如果出現異常等待的狀態可以核查一下。
  6. [interact]
  執行完成後保持互動狀態,把控制權交給控制檯,這個時候就可以手工操作了。如果沒有這一句登入完成後會退出,而不是留在遠端終端上。如果你只是登入過去執行
  #!/usr/bin/expect #注意安裝的路徑,不確定 whereis expect 一下
  # Change a login shell to bash
  set user [lindex $argv 0]
  spawn bash $user
  expect "]:"
  send "/bin/bash "
  expect eof
  exit

相關文章