summaryrefslogtreecommitdiff
path: root/scan/scan.py
diff options
context:
space:
mode:
authorjerome <jerome@xlinfo.fr>2025-10-12 17:41:43 +0200
committerjerome <jerome@xlinfo.fr>2025-10-12 17:41:43 +0200
commitec8893a097a6c0fffebd7db9e4a5568a3bf4df47 (patch)
treeffebe60c3aa98df05d14aec8cea937430272c1ec /scan/scan.py
parentba41fa46e69dbb264dfbed1b9fca5daab44a07c7 (diff)
downloadpython-ec8893a097a6c0fffebd7db9e4a5568a3bf4df47.tar.gz
python-ec8893a097a6c0fffebd7db9e4a5568a3bf4df47.zip
organisation
Diffstat (limited to 'scan/scan.py')
-rw-r--r--scan/scan.py25
1 files changed, 25 insertions, 0 deletions
diff --git a/scan/scan.py b/scan/scan.py
new file mode 100644
index 0000000..38150b2
--- /dev/null
+++ b/scan/scan.py
@@ -0,0 +1,25 @@
+import sys
+import socket
+
+def scan(host,*ports):
+ for port in ports:
+ s=socket.socket(socket.AF_INET, socket.SOCK_STREAM)
+ s.settimeout(2) # Set a 2-second timeout
+ addr_server=(host,int(port))
+ tentative=s.connect_ex(addr_server) #connect_ex renvoie 0 en cas de succès...
+ if tentative==0:
+ print(f"Le port {port} ouvert")
+ try:
+ print(s.recv(1024).decode().strip())
+ except TimeoutError:
+ pass
+ else:
+ print(f"Le port {port} fermé")
+ s.close()
+
+if __name__ == "__main__" :
+ try:
+ scan(sys.argv[1],*sys.argv[2:])
+ except:
+ print(f"{sys.argv[0]} demande un hôte et une liste de ports en arguments")
+