细数微软Exchange的那些恐怖漏洞

在一些场景里,我们可能需要同时在多台服务器上执行命令,如果一台台登录服务器执行嘛,这效率未免太低了。

有没有什么比较简单的方式,可以实现批量在多台服务器上执行命令呢。

场景1:MSF批量执行命令

从攻击者的角度来说,通过MSF获取到了多个session,如何批量在这些服务器上执行命令?

批量执行meterpreter命令


  1. session -C “命令” 

批量执行cmd命令


  1. session -c “命令” 
场景2:Windows服务器批量执行命令

在Windows中有很多种方式可以实现横向移动,通过系统自带命令或工具可以实现。但如果我们需要在多台服务器上执行命令,有没有一种比较简洁的方式?

PsExec一行命令就可以实现:


  1. PsExec.exe @file -u administrator -p  xxxx  -s -i -c 1.bat 

如上,PsExec将在file文件中列出的每台计算机上执行1.bat的内容。

场景3:Linux服务器批量执行命令

在Linux自动化运维里,有很多类似的工具,可以实现批量命令执行,如Ansible、SaltStack、Fabric、Puppet、Chef等。

这里介绍两种简单的方式,通过编写shell/python脚本快速实现批量命令执行。

(1)使用expect批量自动登录服务器并执行命令


  1. #!/bin/bash 
  2. cat iplist|while read line #iplist文件中存放了IP地址和密码,每行格式为“IP地址 密码” 
  3. do 
  4.     a=($line)                     
  5.     /usr/bin/expect <<EOF        
  6.     spawn ssh root@${a[0]}      
  7.     expect { 
  8.     "*yes/no" { send "yes\r"; exp_continue} 
  9.     "*password:" { send "${a[1]}\r" }  
  10.     } 
  11.     expect "#" 
  12.     send "whoami\r" 
  13.     send "ip add\r"                 
  14.     send "exit\r"            
  15.     expect eof 
  16.     EOF 
  17. done 
【声明】:芜湖站长网内容转载自互联网,其相关言论仅代表作者个人观点绝非权威,不代表本站立场。如您发现内容存在版权问题,请提交相关链接至邮箱:bqsm@foxmail.com,我们将及时予以处理。

相关文章