網(wǎng)站首頁 編程語言 正文
前言:
通過端口掃描我們可以知道目標主機都開放了哪些服務,下面通過TCP connect來實現(xiàn)一個TCP全連接端口掃描器。
一個簡單的端口掃描器
#!/usr/bin/python3
# -*- coding: utf-8 -*-
from socket import *
def portScanner(host,port):
try:
s = socket(AF_INET,SOCK_STREAM)
s.connect((host,port))
print('[+] %d open' % port)
s.close()
except:
print('[-] %d close' % port)
def main():
setdefaulttimeout(1)
for p in range(1,1024):
portScanner('192.168.0.100',p)
if __name__ == '__main__':
main()
說明:
- 原理:對不同端口進行TCP連接,根據(jù)是否連接成功來判斷端口是否打開
- AF_INET指定使用IPv4協(xié)議,SOCK_STREAM指定使用面向流的TCP協(xié)議
- connect((host, port)),向指定的IP:端口發(fā)起連接
- setdefaulttimeout(1),默認超時時間為1秒
多線程版本
#!/usr/bin/python3
# -*- coding: utf-8 -*-
from socket import *
import threading
lock = threading.Lock()
openNum = 0
threads = []
def portScanner(host,port):
global openNum
try:
s = socket(AF_INET,SOCK_STREAM)
s.connect((host,port))
lock.acquire()
openNum+=1
print('[+] %d open' % port)
lock.release()
s.close()
except:
pass
def main():
setdefaulttimeout(1)
for p in range(1,1024):
t = threading.Thread(target=portScanner,args=('192.168.0.100',p))
threads.append(t)
t.start()
for t in threads:
t.join()
print('[*] The scan is complete!')
print('[*] A total of %d open port ' % (openNum))
if __name__ == '__main__':
main()
說明:
- 使用多線程,1、t = threading.Thread() 2、t.start() 3、t.join()
- 多線程要保證線程安全(共享變量的一致性)就要對處理共享變量的代碼段加鎖
原文鏈接:https://juejin.cn/post/7099242579958431751
相關(guān)推薦
- 2022-08-14 hyper-v如何配置NAT網(wǎng)絡的實現(xiàn)_Hyper-V
- 2023-12-18 Mybatisplus的增刪改查
- 2022-11-02 Qt5.14.2使用虛擬鍵盤的關(guān)鍵代碼_C 語言
- 2022-11-07 將.py文件轉(zhuǎn)化為.exe文件的詳細過程_python
- 2022-09-26 Linux系統(tǒng)監(jiān)控(top,ps,netstat,kill命令),定時任務,系統(tǒng)啟動(系統(tǒng)的啟動級別
- 2022-07-12 C++重載運算符時函數(shù)類型的選擇與類的類型轉(zhuǎn)換
- 2022-07-10 Spring依賴注入的幾種方式詳解
- 2022-11-07 react使用websocket實時通信方式_React
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細win安裝深度學習環(huán)境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支