Python-nmap 네트워크 스캐닝 및 스니핑 툴킷 사용에 대한 튜토리얼
nmap 개념
Network Mapper라고도 알려진 NMap은 원래 Linux에서 네트워크 스캐닝 및 스니핑 툴킷이었습니다.
nmap은 인터넷에서 컴퓨터의 개방형 네트워크 연결을 검색하는 데 사용되는 네트워크 연결 검색 소프트웨어입니다. 어떤 서비스가 어떤 연결에서 실행되고 있는지 확인하고 컴퓨터가 어떤 운영 체제를 실행하고 있는지 추론합니다(이를 핑거프린팅이라고도 함). 네트워크 관리자가 반드시 사용해야 하는 소프트웨어 중 하나이며 네트워크 시스템 보안을 평가하는 데 사용됩니다.
네트워크 보안에 사용되는 대부분의 도구와 마찬가지로 nmap도 많은 해커와 해커(스크립트 키디라고도 함)가 선호하는 도구입니다. 시스템 관리자는 nmap을 사용하여 작업 환경에서 서버의 무단 사용을 탐지할 수 있지만 해커는 nmap을 사용하여 대상 컴퓨터의 네트워크 설정을 수집하여 공격을 계획합니다.
Nmap은 시스템 취약점 평가 소프트웨어인 Nessus와 혼동되는 경우가 많습니다. Nmap은 침입 탐지 시스템의 감시를 피하고 대상 시스템의 일상적인 작업에 영향을 미치지 않도록 스텔스 방법을 사용합니다.
Nmap The Matrix에서는 SSH1의 32비트 순환 중복 검사 취약점과 함께 Trinity가 발전소의 에너지 관리 시스템에 침입하는 데 사용되었습니다.
nmap 기능
에는 세 가지 기본 기능이 있습니다. 하나는 호스트 그룹이 온라인인지 여부를 감지하는 것이고, 두 번째는 호스트 포트를 스캔하고 제공된 네트워크 서비스를 스니핑하는 것입니다. 주인. Nmap은 적게는 두 개의 노드로 구성된 LAN부터 최대 500개 이상의 노드로 구성된 네트워크까지 스캔하는 데 사용할 수 있습니다. Nmap을 사용하면 사용자가 스캐닝 기술을 맞춤 설정할 수도 있습니다. 일반적으로 ICMP 프로토콜을 사용하는 간단한 핑 작업은 UDP 또는 TCP 포트를 심층적으로 탐지할 수 있으며, 호스트에서 사용하는 운영 체제까지 모든 탐지 결과를 다양한 형식으로 기록할 수 있습니다. 분석. 분석 작업.
핑 스캔을 수행하고 추가 테스트(예: 포트 스캔 또는 운영 체제 감지) 없이 스캔에 응답한 호스트를 인쇄합니다.
nmap -sP 192.168.1.0/24
지정된 네트워크의 각 호스트만 나열하고 대상 호스트로 패킷을 보내지 않습니다. :
nmap -sL 192.168.1.0/24
대상 호스트의 열린 포트를 감지하려면 쉼표로 구분된 포트 목록을 지정할 수 있습니다(예: -PS22, 23, 25, 80).
nmap -PS 192.168.1.234
UDP 핑을 사용하여 호스트 감지:
nmap -PU 192.168.1.0/24
가장 자주 사용되는 스캔 옵션: 반 개방형 스캔이라고도 알려진 SYN 스캔은 완전한 TCP 연결을 열지 않고 매우 빠르게 실행됩니다.
nmap -sS 192.168.1.0/24
nmap 설치
이 기사에서는 Linux Ubuntu16.04를 예로 사용합니다. , 그리고 마지막으로 Python을 주로 사용합니다
1. 먼저 nmap을 설치합니다
sudo apt-get install nmap
2. 그런 다음 python-nmap을 설치합니다
sudo pip install python-nmap
설치 후 nmap을 Python으로 가져오고 성공하는지 테스트합니다
com@pythontab:~# python Python 2.7.12 (default, Dec 3 2016, 10:42:27) [GCC 4.4.7 20120313 (Red Hat 4.4.7-17)] on linux2 Type "help", "copyright", "credits" or "license" for more information. >>> import nmap
nmap을 실행합니다. python
1. 간단한 작은 케이스
PortScanner 인스턴스를 생성한 다음 IP 114.114.114.114의 포트 20-443을 스캔합니다.
import nmap nm = nmap.PortScanner() ret = nm.scan('114.114.114.114','20') print ret
반환 형식은 다음과 같습니다.
{ 'nmap': { 'scanstats': {'uphosts': '1', 'timestr': 'Tue Oct 25 11:30:47 2016', 'downhosts': '0', 'totalhosts': '1', 'elapsed': '1.11'}, 'scaninfo': {'tcp': {'services': '20', 'method': 'connect'}}, 'command_line': 'nmap -oX - -p 20 -sV 115.239.210.26' }, 'scan': { '115.239.210.26': { 'status': {'state': 'up', 'reason': 'syn-ack'}, 'hostnames': [{'type': '', 'name': ''}], 'vendor': {}, 'addresses': {'ipv4': '115.239.210.26'}, 'tcp': {20: {'product': '', 'state': 'filtered', 'version': '', 'name': 'ftp-data', 'conf': '3', 'extrainfo': '', 'reason': 'no-response', 'cpe': ''} } } } }
2. 내장 방식:
간단한 정보도 출력할 수 있습니다
import nmap nm = nmap.PortScanner() print nm.scaninfo() # {u'tcp': {'services': u'20-443', 'method': u'syn'}} print nm.command_line() # u'nmap -oX - -p 20-443 -sV 114.114.114.114'
호스트 수 확인
print nm.all_hosts()
[u'114.114.114.114' ]
호스트 보기 상세 정보
nm['114.114.114.114']
호스트에 포함된 모든 프로토콜 보기
nm['114.114.114.114'].all_protocols()
호스트의 어떤 포트가 tcp 프로토콜을 제공하는지 보기
nm['114.114.114.114']['tcp'] nm['114.114.114.114']['tcp'].keys()
포트가 tcp 프로토콜을 제공하는지 보기
nm['114.114.114.114'].has_tcp(21)
nmap 실행을 위한 매개변수는 다음과 같습니다
nm.scan(hosts='192.168.1.0/24', arguments='-n -sP -PE -PA21,23,80,3389')
위 내용은 Python-nmap 네트워크 스캐닝 및 스니핑 툴킷 사용에 대한 튜토리얼의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











Linux 터미널에서 Python 버전을 보려고 할 때 Linux 터미널에서 Python 버전을 볼 때 권한 문제에 대한 솔루션 ... Python을 입력하십시오 ...

10 시간 이내에 컴퓨터 초보자 프로그래밍 기본 사항을 가르치는 방법은 무엇입니까? 컴퓨터 초보자에게 프로그래밍 지식을 가르치는 데 10 시간 밖에 걸리지 않는다면 무엇을 가르치기로 선택 하시겠습니까?

Fiddlerevery Where를 사용할 때 Man-in-the-Middle Reading에 Fiddlereverywhere를 사용할 때 감지되는 방법 ...

Python의 Pandas 라이브러리를 사용할 때는 구조가 다른 두 데이터 프레임 사이에서 전체 열을 복사하는 방법이 일반적인 문제입니다. 두 개의 dats가 있다고 가정 해

Uvicorn은 HTTP 요청을 어떻게 지속적으로 듣습니까? Uvicorn은 ASGI를 기반으로 한 가벼운 웹 서버입니다. 핵심 기능 중 하나는 HTTP 요청을 듣고 진행하는 것입니다 ...

Investing.com의 크롤링 전략 이해 많은 사람들이 종종 Investing.com (https://cn.investing.com/news/latest-news)에서 뉴스 데이터를 크롤링하려고합니다.

파이썬에서 문자열을 통해 객체를 동적으로 생성하고 메소드를 호출하는 방법은 무엇입니까? 특히 구성 또는 실행 해야하는 경우 일반적인 프로그래밍 요구 사항입니다.
