網站首頁 編程語言 正文
主要是以Nmap舉例編寫,其中涉及的協議暫不過多討論
喜歡用Python寫腳本的小伙伴可以跟著一起寫一寫呀。
編寫環境:Python2.x
00x1:需要用到的模塊
需要用到的模塊如下:
import socket
import ipaddr
00x2:創建socket對象
首先我們先進寫一個簡單的通信
先創建socket對象
sockect = socket.socket()
因為主要就是進行端口掃描,不需要等待對方回復通信,所以我們需要再用異常處理
Ok,沒毛病
00x3:處理ip
我們接下來處理ip,當輸入一個 127.0.0.1/24 讓他自動分成ip
這就要用到ipaddr
ip = raw_input('\nIP:')
ips = ipaddr.IPNetwork(ip)
for ip in ips:
print ip
自動生成C段ok,當然你輸入B段也是可以的,他會自動處理
強制轉換為字符串,不然無法執行
ip = str(ip)
00x4:測試用例
我們來測試一下,以百度為例:
速度有點慢,有的可能會超時,我們再限制一下超時時間
try:
sockect.settimeout(0.2)
sockect.connect((ip,port))
print "\n[+]%s open %s"%(ip,port)
except:
sockect.close()
修改后快了很多
00x5:設定掃描端口
我們來設定掃描的端口
portlist = [21,80,445,3306,27017,6379.139,135]
ok,這就完成了一個端口掃描器
當然你可以自定義端口,以及根據自己的需求來編寫
00x6:完整代碼
#!/usr/bin/python
#-*- coding:utf-8 -*-
import socket
import ipaddr
def portscan(ip,port):
sockect = socket.socket()
try:
sockect.settimeout(0.2)
sockect.connect((ip,port))
print "[+]%s open %s"%(ip,port)
except:
sockect.close()
portlist = [21,80,443,445,3306,27017,6379]
if __name__ == '__main__':
ip = raw_input('\nIP:')
print ""
ips = ipaddr.IPNetwork(ip)
for ip in ips:
for port in portlist:
portscan(str(ip),port)
原文鏈接:https://blog.csdn.net/XunanSec/article/details/124748979
相關推薦
- 2023-05-18 深入了解Android?Okio的超時機制_Android
- 2022-10-12 golang?執行命令行的實現_Golang
- 2022-01-04 變量提升,函數提升及其優先級關系
- 2022-01-11 Cookie、sessionStorage和localStorage的區別
- 2023-03-22 gin正確多次讀取http?request?body內容實現詳解_Golang
- 2022-03-06 C#多種操作excel的方法比較_C#教程
- 2023-01-13 Go?cobra庫使用教程_Golang
- 2021-11-08 深入解析golang中的標準庫flag_Golang
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支