绕过bash

时间:2016-04-22 13:15:04

标签: linux bash shell ssh

所以我有一个小脚本应该通过不同的服务器连接到1000个左右的帐户,如下所示。

for account in $(cat $SSH_LIST)
  do echo -e "\n$account\n"
  SERVER=$(echo $account | cut -d',' -f1 | awk '{print tolower($0)}') ; USER=$(echo $account | cut -d',' -f2) ; PASS=$(echo $account | cut -d',' -f3)
  sshpass -p $PASS ssh -o StrictHostKeyChecking=no $USER@$SERVER "ls passwd.cdb && exit"

问题是,当ssh命中权限被拒绝时,脚本退出。可以理解的是,SSH Permission Denied就像退出代码一样,退出了脚本。我需要它来简单地记录被拒绝的权限并继续它的快乐方式SSH' ing。

有什么建议吗?

3 个答案:

答案 0 :(得分:7)

通常情况下,bash不会在第一个错误时退出,除非在脚本中将$(document).ajaxSend(function () { $.mobile.loading("show") }).ajaxStop(function () { $.mobile.loading("hide") }); 设置得更高。尝试在set -e循环之前加上它。

for

P.S。您在循环结束时错过了set +e 。我认为这只是一个剪切和粘贴错误。

答案 1 :(得分:3)

尝试以下方法:

if ! sshpass -p $PASS ssh -o StrictHostKeyChecking=no $USER@$SERVER "ls passwd.cdb && exit"; then
    echo >&2 "WARNING: access denied for $USER@$SERVER"
fi

您也可以使用逻辑运算符OR

sshpass -p $PASS ssh -o StrictHostKeyChecking=no $USER@$SERVER "ls passwd.cdb && exit" ||
    echo >&2 "WARNING: access denied for $USER@$SERVER"

答案 2 :(得分:1)

刚刚在这里更新,我知道已经有一段时间了,一直很忙:)。事实证明-e是在脚本顶部的一些混淆代码中设置的。让混淆代码的人删除它。还要感谢slava semushin记录拒绝访问消息的好主意。