네트워크 통신에 대한 입문서
침투 테스트를 수행하려면 펜 테스터가 IP 주소, 클래스 별 서브넷, 클래스없는 서브넷, 포트 및 브로드 캐스팅 네트워크와 같은 기본 네트워킹 개념에 대해 알고 있어야한다고 항상 들었습니다. 첫 번째 이유는 어떤 호스트가 승인 된 범위에 살고 있는지, 어떤 서비스, 포트 및 그들이 열려 있고 반응하는 기능과 같은 활동이 평가자가 침투 테스트에서 수행 할 활동의 종류를 결정한다는 것입니다. 환경은 계속 변하고 시스템은 종종 재 할당됩니다. 따라서 이전 취약점이 다시 발생할 수 있으며 네트워크 스캔에 대한 충분한 지식이 없으면 초기 스캔을 다시 수행해야 할 수 있습니다. 다음 섹션에서는 네트워크 통신의 기본 사항에 대해 설명합니다.
참조 모델
참조 모델은 컴퓨터 네트워크를 사용하는 사람들이 물리적 범위가 넓고 네트워크 장치가 이기종 아키텍처를 가질 수 있기 때문에 전 세계적으로 허용되는 표준화 수단을 제공합니다. 이기종 장치 간의 통신을 제공하려면 이러한 장치가 통신 할 수있는 방법을 제공 할 표준 모델, 즉 참조 모델이 필요합니다.
OSI 모델과 TCP / IP 참조 모델과 같은 두 가지 참조 모델이 있습니다. 그러나 OSI 모델은 가상 모델이지만 TCP / IP는 실용적인 모델입니다.
OSI 모델
개방형 시스템 인터페이스는 ISO (International Organization of Standardization)에 의해 설계되었으므로 ISO-OSI 모델이라고도합니다.
OSI 모델은 다음 다이어그램과 같이 7 개의 계층으로 구성됩니다. 각 계층에는 특정 기능이 있지만 각 계층은 위 계층에 서비스를 제공합니다.
물리적 계층
물리 계층은 다음 활동을 담당합니다.
물리적 연결 활성화, 유지 및 비활성화.
전송에 필요한 전압 및 데이터 속도를 정의합니다.
디지털 비트를 전기 신호로 변환합니다.
연결이 단방향, 반이중 또는 전이중인지 결정합니다.
데이터 링크 계층
데이터 링크 계층은 다음과 같은 기능을 수행합니다.
물리적 링크를 통해 전송 될 정보에 대한 동기화 및 오류 제어를 수행합니다.
오류 감지를 활성화하고 전송할 데이터에 오류 감지 비트를 추가합니다.
네트워크 계층
네트워크 계층은 다음과 같은 기능을 수행합니다.
다양한 채널을 통해 다른 쪽 끝으로 신호를 라우팅합니다.
어떤 라우트 데이터가 취해야하는지 결정하여 네트워크 컨트롤러 역할을합니다.
나가는 메시지를 패킷으로 나누고 들어오는 패킷을 더 높은 수준의 메시지로 조합합니다.
전송 계층
전송 계층은 다음과 같은 기능을 수행합니다.
데이터 전송이 병렬 경로 또는 단일 경로에서 발생해야하는지 결정합니다.
다중화를 수행하고 데이터를 분할합니다.
데이터 그룹을 더 작은 단위로 분할하여 네트워크 계층에서보다 효율적으로 처리합니다.
전송 계층은 한 끝에서 다른 끝으로 데이터 전송을 보장합니다.
세션 계층
세션 계층은 다음과 같은 기능을 수행합니다.
메시지를 관리하고 서로 다른 두 응용 프로그램 간의 대화를 동기화합니다.
로그온 및 로그 오프, 사용자 식별, 청구 및 세션 관리를 제어합니다.
프리젠 테이션 레이어
프레젠테이션 계층은 다음과 같은 기능을 수행합니다.
이 계층은 정보가 수신 시스템이 이해하고 사용할 수있는 형태로 전달되도록합니다.
응용 계층
응용 프로그램 계층은 다음과 같은 기능을 수행합니다.
여러 가지 정보 조작, 정보 파일 재전송, 결과 배포 등 다양한 서비스를 제공합니다.
LOGIN 또는 암호 확인과 같은 기능도 응용 프로그램 계층에서 수행됩니다.
TCP / IP 모델
전송 제어 프로토콜 및 인터넷 프로토콜 (TCP / IP) 모델은 실용적인 모델이며 인터넷에서 사용됩니다.
TCP / IP 모델은 두 계층 (물리적 및 데이터 링크 계층)을 호스트-네트워크 계층이라는 하나의 계층으로 결합합니다. 다음 다이어그램은 TCP / IP 모델의 다양한 계층을 보여줍니다.
응용 계층
이 계층은 OSI 모델의 계층과 동일하며 다음과 같은 기능을 수행합니다.
여러 가지 정보 조작, 정보 파일 재전송, 결과 배포 등 다양한 서비스를 제공합니다.
응용 프로그램 계층은 LOGIN 또는 암호 확인과 같은 기능도 수행합니다.
다음은 응용 프로그램 계층에서 사용되는 다른 프로토콜입니다.
- TELNET
- FTP
- SMTP
- DN
- HTTP
- NNTP
전송 계층
OSI 모델의 전송 계층과 동일한 기능을 수행합니다. 전송 계층과 관련된 다음 중요 사항을 고려하십시오.
종단 간 전송을 위해 TCP 및 UDP 프로토콜을 사용합니다.
TCP는 안정적이고 연결 지향적 인 프로토콜입니다.
TCP는 흐름 제어도 처리합니다.
UDP는 신뢰할 수 없으며 연결이 적은 프로토콜은 흐름 제어를 수행하지 않습니다.
이 계층에는 TCP / IP 및 UDP 프로토콜이 사용됩니다.
인터넷 계층
이 계층의 기능은 호스트가 패킷을 네트워크에 삽입 한 다음 대상으로 독립적으로 이동할 수 있도록하는 것입니다. 그러나 패킷 수신 순서는 전송 된 순서와 다를 수 있습니다.
인터넷 프로토콜 (IP)은 인터넷 계층에 사용됩니다.
호스트-네트워크 계층
이것은 TCP / IP 모델에서 가장 낮은 계층입니다. 호스트는 프로토콜을 사용하여 네트워크에 연결해야 IP 패킷을 보낼 수 있습니다. 이 프로토콜은 호스트마다, 네트워크마다 다릅니다.
이 계층에서 사용되는 다른 프로토콜은 다음과 같습니다.
- ARPANET
- SATNET
- LAN
- 패킷 라디오
유용한 아키텍처
다음은 네트워크 통신에 사용되는 몇 가지 유용한 아키텍처입니다.
이더넷 프레임 아키텍처
Robert Metcalfe라는 엔지니어는 1973 년 IEEE 표준 802.3에 따라 정의 된 이더넷 네트워크를 처음 발명했습니다.이 네트워크는 워크 스테이션과 프린터 간의 데이터를 상호 연결하고 전송하는 데 처음 사용되었습니다. LAN의 80 % 이상이 속도, 저렴한 비용 및 설치 용이성 때문에 이더넷 표준을 사용합니다. 반면에 프레임에 대해 이야기하면 데이터가 호스트에서 호스트로 이동합니다. 프레임은 MAC 주소, IP 헤더, 시작 및 끝 구분 기호 등과 같은 다양한 구성 요소로 구성됩니다.
이더넷 프레임은 프리앰블과 SFD로 시작합니다. 이더넷 헤더에는 소스 및 대상 MAC 주소가 모두 포함되며 그 뒤에 프레임 페이로드가 표시됩니다. 마지막 필드는 오류를 감지하는 데 사용되는 CRC입니다. 기본 이더넷 프레임 구조는 IEEE 802.3 표준에 정의되어 있으며, 다음과 같이 설명됩니다.
이더넷 (IEEE 802.3) 프레임 형식
이더넷 패킷은 이더넷 프레임을 페이로드로 전송합니다. 다음은 각 필드의 설명과 함께 이더넷 프레임의 그래픽 표현입니다.
분야 명 | 전문 | SFD (프레임 구분자 시작) | 목적지 MAC | 소스 MAC | 유형 | 데이터 | CRC |
---|---|---|---|---|---|---|---|
크기 (바이트) | 7 | 1 | 6 | 6 | 2 | 46-1500 | 4 |
전문
이더넷 프레임 앞에는 7 바이트 크기의 프리앰블이옵니다.이 프레임은 수신 시스템에 프레임이 시작되고 있음을 알리고 송신자와 수신자가 비트 동기화를 설정할 수 있도록합니다.
SFD (프레임 구분 기호 시작)
대상 MAC 주소 필드가 다음 바이트로 시작 함을 나타내는 데 사용되는 1 바이트 필드입니다. 때때로 SFD 필드는 Preamble의 일부로 간주됩니다. 이것이 프리앰블이 많은 곳에서 8 바이트로 간주되는 이유입니다.
Destination MAC − 이것은 수신 시스템의 주소가있는 6 바이트 필드입니다.
Source MAC − 이것은 송신 시스템의 주소가있는 6 바이트 필드입니다.
Type− 프레임 내부의 프로토콜 종류를 정의합니다. 예 : IPv4 또는 IPv6. 크기는 2 바이트입니다.
Data−이를 Payload라고도하며 실제 데이터가 여기에 삽입됩니다. 길이는 46-1500 바이트 여야합니다. 길이가 46 바이트 미만이면 가능한 최소 길이 (즉, 46)를 충족하기 위해 패딩 0이 추가됩니다.
CRC (Cyclic Redundancy Check) − 32 비트 CRC가 포함 된 4 바이트 필드로 손상된 데이터를 감지 할 수 있습니다.
확장 이더넷 프레임 (이더넷 II 프레임) 형식
다음은 1500 바이트보다 큰 페이로드를 얻을 수있는 확장 이더넷 프레임의 그래픽 표현입니다.
분야 명 | 목적지 MAC | 소스 MAC | 유형 | DSAP | SSAP | Ctrl | 데이터 | CRC |
---|---|---|---|---|---|---|---|---|
크기 (바이트) | 6 | 6 | 2 | 1 | 1 | 1 | > 46 | 4 |
IEEE 802.3 이더넷 프레임과 다른 필드에 대한 설명은 다음과 같습니다.
DSAP (Destination Service Access Point)
DSAP는 메시지를 수신 할 네트워크 계층 엔티티의 논리 주소를 나타내는 1 바이트 길이의 필드입니다.
SSAP (소스 서비스 액세스 포인트)
SSAP는 메시지를 만든 네트워크 계층 엔터티의 논리적 주소를 나타내는 1 바이트 길이의 필드입니다.
Ctrl
1 바이트 제어 필드입니다.
IP 패킷 아키텍처
인터넷 프로토콜은 TCP / IP 프로토콜 제품군의 주요 프로토콜 중 하나입니다. 이 프로토콜은 OSI 모델의 네트워크 계층과 TCP / IP 모델의 인터넷 계층에서 작동합니다. 따라서이 프로토콜은 논리 주소를 기반으로 호스트를 식별하고 기본 네트워크를 통해 호스트간에 데이터를 라우팅 할 책임이 있습니다. IP는 IP 주소 지정 체계로 호스트를 고유하게 식별하는 메커니즘을 제공합니다. IP는 최선의 전달을 사용합니다. 즉, 패킷이 대상 호스트로 전달된다는 보장은 없지만 대상에 도달하기 위해 최선을 다합니다.
이후 섹션에서는 두 가지 다른 버전의 IP에 대해 알아 봅니다.
IPv4
이것은 32 비트 논리 주소를 사용하는 인터넷 프로토콜 버전 4입니다. 다음은 필드 설명과 함께 IPv4 헤더의 다이어그램입니다.
버전
이것은 사용 된 인터넷 프로토콜의 버전입니다. 예 : IPv4.
IHL
인터넷 헤더 길이; 전체 IP 헤더의 길이.
DSCP
차별화 된 서비스 코드 포인트; 이것이 서비스 유형입니다.
ECN
명시 적 혼잡 알림; 경로에서 본 혼잡에 대한 정보를 전달합니다.
총 길이
전체 IP 패킷의 길이 (IP 헤더 및 IP 페이로드 포함).
신분증
IP 패킷이 전송 중에 조각화되면 모든 조각에 동일한 식별 번호가 포함됩니다.
플래그
네트워크 리소스에서 요구하는대로 IP 패킷이 처리하기에 너무 큰 경우 이러한 '플래그'는 조각화 될 수 있는지 여부를 알려줍니다. 이 3 비트 플래그에서 MSB는 항상 '0'으로 설정됩니다.
조각 오프셋
이 오프셋은 원래 IP 패킷에서 조각의 정확한 위치를 알려줍니다.
TTL (Time to Live)
네트워크에서 루핑을 방지하기 위해 모든 패킷은이 패킷이 교차 할 수있는 라우터 (홉) 수를 네트워크에 알려주는 TTL 값 세트와 함께 전송됩니다. 각 홉에서 값은 1 씩 감소하고 값이 0에 도달하면 패킷이 삭제됩니다.
실험 계획안
대상 호스트의 네트워크 계층에이 패킷이 속한 프로토콜, 즉 다음 수준의 프로토콜을 알려줍니다. 예를 들어 ICMP의 프로토콜 번호는 1, TCP는 6, UDP는 17입니다.
헤더 체크섬
이 필드는 전체 헤더의 체크섬 값을 유지하는 데 사용되며 패킷이 오류없이 수신되었는지 확인하는 데 사용됩니다.
소스 주소
패킷 발신자 (또는 소스)의 32 비트 주소입니다.
목적지 주소
패킷 수신자 (또는 대상)의 32 비트 주소입니다.
옵션
IHL 값이 5보다 큰 경우 사용되는 선택적 필드입니다. 이러한 옵션에는 보안, 레코드 경로, 타임 스탬프 등과 같은 옵션에 대한 값이 포함될 수 있습니다.
IPv4에 대해 자세히 알아 보려면이 링크를 참조하십시오 -www.tutorialspoint.com/ipv4/index.htm
IPv6
인터넷 프로토콜 버전 6은 이전 버전 인 IPv4가 네트워크 계층 (계층 -3)에서 작동하는 최신 통신 프로토콜입니다. 엄청난 양의 논리적 주소 공간을 제공하는 것과 함께이 프로토콜은 IPv4의 단점을 해결하는 풍부한 기능을 가지고 있습니다. 다음은 필드 설명과 함께 IPv4 헤더의 다이어그램입니다.
버전 (4 비트)
인터넷 프로토콜 (0110)의 버전을 나타냅니다.
트래픽 클래스 (8 비트)
이 8 비트는 두 부분으로 나뉩니다. 가장 중요한 6 비트는 서비스 유형에 사용되어 라우터가이 패킷에 어떤 서비스를 제공해야하는지 알려줍니다. ECN (Explicit Congestion Notification)에는 최하위 2 비트가 사용됩니다.
흐름 레이블 (20 비트)
이 레이블은 통신에 속하는 패킷의 순차적 흐름을 유지하는 데 사용됩니다. 소스는 라우터가 특정 패킷이 특정 정보 흐름에 속함을 식별 할 수 있도록 시퀀스에 레이블을 지정합니다. 이 필드는 데이터 패킷의 재정렬을 방지하는 데 도움이됩니다. 스트리밍 / 실시간 미디어 용으로 설계되었습니다.
페이로드 길이 (16 비트)
이 필드는 특정 패킷이 페이로드에 포함하는 정보의 양을 라우터에 알리는 데 사용됩니다. 페이로드는 확장 헤더와 상위 계층 데이터로 구성됩니다. 16 비트에서는 최대 65535 바이트를 표시 할 수 있습니다. 그러나 확장 헤더에 Hop-by-Hop 확장 헤더가 포함 된 경우 페이로드는 65535 바이트를 초과 할 수 있으며이 필드는 0으로 설정됩니다.
다음 헤더 (8 비트)
이 필드는 확장 헤더의 유형을 나타 내기 위해 사용되거나 확장 헤더가없는 경우 상위 계층 PDU를 나타냅니다. 상위 계층 PDU 유형에 대한 값은 IPv4와 동일합니다.
홉 제한 (8 비트)
이 필드는 네트워크에서 무한 루프하는 패킷을 중지하는 데 사용됩니다. 이것은 IPv4의 TTL과 동일합니다. Hop Limit 필드의 값은 링크 (라우터 / 홉)를 통과 할 때 1 씩 감소합니다. 필드가 0에 도달하면 패킷이 삭제됩니다.
소스 주소 (128 비트)
이 필드는 패킷 발신자의 주소를 나타냅니다.
대상 주소 (128 비트)
이 필드는 패킷의 의도 된 수신자 주소를 제공합니다.
IPv6에 대해 자세히 알아 보려면 다음 링크를 참조하십시오. www.tutorialspoint.com/ipv6/index.htm
TCP (전송 제어 프로토콜) 헤더 아키텍처
TCP는 통신을 시작하기 전에 두 시스템간에 세션이 설정되는 연결 지향 프로토콜이라는 것을 알고 있습니다. 통신이 완료되면 연결이 종료됩니다. TCP는 두 시스템간에 연결 소켓을 설정하기 위해 3 방향 핸드 셰이크 기술을 사용합니다. 3 방향 핸드 셰이크는 SYN, SYN-ACK 및 ACK의 세 가지 메시지가 두 시스템간에주고받는 것을 의미합니다. 두 시스템, 시작 및 대상 시스템 간의 작업 단계는 다음과 같습니다.
Step 1 − Packet with SYN flag set
먼저 연결을 시작하려는 모든 시스템은 SYN 플래그가 설정된 패킷으로 시작합니다.
Step 2 − Packet with SYN-ACK flag set
이제이 단계에서 대상 시스템은 SYN 및 ACK 플래그가 설정된 패킷을 반환합니다.
Step 3 − Packet with ACK flag set
마지막으로 시작 시스템은 ACK 플래그가 설정된 원래 대상 시스템으로 패킷을 반환합니다.
다음은 필드 설명과 함께 TCP 헤더 다이어그램입니다.
소스 포트 (16 비트)
전송 장치에서 응용 프로그램 프로세스의 소스 포트를 식별합니다.
대상 포트 (16 비트)
수신 장치에서 응용 프로그램 프로세스의 대상 포트를 식별합니다.
시퀀스 번호 (32 비트)
세션에서 세그먼트의 데이터 바이트 시퀀스 번호입니다.
승인 번호 (32 비트)
ACK 플래그가 설정되면이 번호는 예상되는 데이터 바이트의 다음 시퀀스 번호를 포함하고 수신 된 이전 데이터의 승인으로 작동합니다.
데이터 오프셋 (4 비트)
이 필드는 TCP 헤더의 크기 (32 비트 단어)와 전체 TCP 세그먼트에서 현재 패킷의 데이터 오프셋을 모두 의미합니다.
예약 됨 (3 비트)
향후 사용을 위해 예약되어 있으며 기본적으로 0으로 설정됩니다.
플래그 (각 1 비트)
NS − 명시 적 혼잡 알림 신호 프로세스는이 Nonce Sum 비트를 사용합니다.
CWR − 호스트가 ECE 비트가 설정된 패킷을 수신하면 ECE가 수신되었음을 확인하도록 Congestion Windows Reduced를 설정합니다.
ECE − 두 가지 의미가 있습니다 −
SYN 비트가 0으로 클리어되면 ECE는 IP 패킷에 CE (혼잡 경험) 비트 세트가 있음을 의미합니다.
SYN 비트가 1로 설정되면 ECE는 장치가 ECT 가능함을 의미합니다.
URG − 긴급 포인터 필드에 중요한 데이터가 있으므로 처리해야 함을 나타냅니다.
ACK− Acknowledgment 필드가 중요 함을 나타냅니다. ACK가 0으로 해제되면 패킷에 승인이 없음을 나타냅니다.
PSH − 설정되면, 버퍼링없이 수신 애플리케이션으로 데이터를 PUSH (오자마자)하기 위해 수신 스테이션에 요청합니다.
RST − 리셋 플래그에는 다음과 같은 기능이 있습니다 −
들어오는 연결을 거부하는 데 사용됩니다.
세그먼트를 거부하는 데 사용됩니다.
연결을 다시 시작하는 데 사용됩니다.
SYN −이 플래그는 호스트 간의 연결을 설정하는 데 사용됩니다.
FIN−이 플래그는 연결을 해제하는 데 사용되며 이후 더 이상 데이터가 교환되지 않습니다. SYN 및 FIN 플래그가있는 패킷에는 시퀀스 번호가 있으므로 올바른 순서로 처리됩니다.
Windows 크기
이 필드는 두 스테이션 간의 흐름 제어에 사용되며 수신기가 세그먼트에 할당 한 버퍼의 양 (바이트)을 나타냅니다. 즉, 수신기가 예상하는 데이터의 양을 나타냅니다.
Checksum −이 필드에는 헤더, 데이터 및 의사 헤더의 체크섬이 포함됩니다.
Urgent Pointer − URG 플래그가 1로 설정된 경우 긴급 데이터 바이트를 가리 킵니다.
Options− 일반 헤더에 포함되지 않는 추가 옵션을 용이하게합니다. 옵션 필드는 항상 32 비트 단어로 설명됩니다. 이 필드에 32 비트 미만의 데이터가 포함 된 경우 32 비트 경계에 도달하기 위해 나머지 비트를 덮는 데 패딩이 사용됩니다.
TCP에 대해 자세히 알아 보려면이 링크를 참조하십시오 — https://www.tutorialspoint.com/data_communication_computer_network/transmission_control_protocol.htm
UDP (사용자 데이터 그램 프로토콜) 헤더 아키텍처
UDP는 연결 지향 프로토콜 인 TCP와 달리 간단한 비 연결 프로토콜입니다. 최소한의 통신 메커니즘이 필요합니다. UDP에서 수신자는 수신 된 패킷에 대한 승인을 생성하지 않고 송신자는 전송 된 패킷의 승인을 기다리지 않습니다. 이러한 단점은이 프로토콜을 신뢰할 수없고 처리하기 쉽게 만듭니다. 다음은 필드 설명과 함께 UDP 헤더의 다이어그램입니다.
소스 포트
이 16 비트 정보는 패킷의 소스 포트를 식별하는 데 사용됩니다.
목적지 포트
이 16 비트 정보는 대상 컴퓨터에서 응용 프로그램 수준 서비스를 식별하는 데 사용됩니다.
길이
길이 필드는 UDP 패킷의 전체 길이 (헤더 포함)를 지정합니다. 16 비트 필드이고 최소값은 8 바이트, 즉 UDP 헤더 자체의 크기입니다.
체크섬
이 필드는 보내기 전에 보낸 사람이 생성 한 체크섬 값을 저장합니다. IPv4에는이 필드가 선택 사항으로 있으므로 체크섬 필드에 값이 포함되지 않은 경우 0이되고 모든 비트가 0으로 설정됩니다.
TCP에 대해 자세히 알아 보려면 다음 링크를 참조하십시오. — 사용자 데이터 그램 프로토콜