> 백엔드 개발 > Golang > Golang은 syn 스캐닝을 구현합니다.

Golang은 syn 스캐닝을 구현합니다.

王林
풀어 주다: 2023-05-13 09:21:07
원래의
1469명이 탐색했습니다.

인터넷이 대중화되면서 네트워크 보안 문제가 점점 심각해지고 있습니다. 네트워크 공격 방법은 끝없이 등장하며 그 중 SYN 스캐닝이 일반적인 공격 방법입니다. SYN 스캐닝은 TCP SYN 패킷을 대상 호스트의 열려 있는 포트로 전송하여 대상 호스트의 접근성을 확인하는 방법입니다. 이 기사에서는 Golang을 사용하여 SYN 스캐닝을 구현하는 방법을 소개합니다.

1. SYN 스캐닝의 원리

SYN 스캐닝은 TCP 3방향 핸드셰이크 프로세스를 기반으로 합니다. 호스트가 다른 호스트의 특정 포트에 연결하려고 하면 대상 호스트에 SYN 패킷을 보내 포트가 열려 있는지 묻습니다. 대상 호스트가 이 SYN 패킷을 수신하고 포트가 실제로 열려 있으면 대상 호스트는 요청 호스트에 대한 응답으로 ACK 플래그와 함께 SYN/ACK 패킷을 보냅니다. 마지막으로 요청 호스트는 TCP 연결을 설정하기 위해 ACK 패킷을 보냅니다. 포트가 열려 있지 않으면 대상 호스트는 연결 요청을 거부하기 위해 RST 패킷을 보냅니다.

따라서 SYN 스캐닝의 원리는 대상 호스트에 SYN 패킷을 보내고 응답을 기다리는 것입니다. 응답이 SYN/ACK 패킷이면 포트가 열려 있음을 나타내고, 응답이 RST 패킷이면 포트가 열려 있지 않음을 나타냅니다.

2. Golang을 사용하여 SYN 스캐닝 구현

Golang은 네트워크 스캐닝 도구를 구현하는 데 매우 적합한 동시성 프로그래밍 언어입니다. 다음으로 Golang을 사용하여 SYN 스캐닝을 구현하겠습니다.

1. TCP 패킷을 보내고 받을 수 있는 연결을 만듭니다.

Golang에서는 "net" 라이브러리를 사용하여 TCP 연결을 구현할 수 있습니다. 여기서는 "net.DialTimeout" 함수를 사용하여 TCP 연결을 생성하고 연결 시간 제한을 설정합니다.

conn, err := net.DialTimeout("tcp", fmt.Sprintf("%s:%d", ipAddress, port), time.Duration(timeout)*time.Millisecond)
로그인 후 복사

2. SYN 패킷 보내기

연결을 만든 후에는 SYN 패킷을 보내야 합니다. "go-socket.io/socket.io-protocol" 라이브러리의 "ErrSig"를 사용하여 SYN 패킷을 생성할 수 있습니다.

SYN := socketio.Packet{
    Type: socketio.SYNT,
}
SYNBytes, err := SYN.Encode(socketio.BINARY)
if err != nil {
    return false, err
}
로그인 후 복사

그런 다음 이 패킷을 대상 호스트로 보내고 싶습니다.

_, err = conn.Write(SYNBytes)
if err != nil {
    return false, err
}
로그인 후 복사

3. 응답 패킷 읽기

마지막으로 응답 패킷을 기다립니다. 응답 패킷은 "bufio.NewReader" 함수를 사용하여 읽을 수 있습니다.

reader := bufio.NewReader(conn)
response, err := reader.ReadByte()
if err != nil {
    return false, err
}
로그인 후 복사

응답이 SYN/ACK 패킷이면 포트가 열려 있음을 나타내고, 응답이 RST 패킷이면 포트가 열려 있지 않음을 나타냅니다.

if response == socketio.SYNACKT.Value() {
    return true, nil
} else {
    return false, nil
}
로그인 후 복사

3. 전체 코드 구현

다음은 Golang을 사용하여 SYN 스캐닝을 구현하는 전체 코드 구현입니다.

package main

import (
    "bufio"
    "fmt"
    "net"
    "time"

    "github.com/go-socket.io/socket.io-protocol"
)

func synScan(ipAddress string, port int, timeout int) (bool, error) {
    conn, err := net.DialTimeout("tcp", fmt.Sprintf("%s:%d", ipAddress, port), time.Duration(timeout)*time.Millisecond)
    if err != nil {
        return false, err
    }
    defer conn.Close()

    SYN := socketio.Packet{
        Type: socketio.SYNT,
    }
    SYNBytes, err := SYN.Encode(socketio.BINARY)
    if err != nil {
        return false, err
    }

    _, err = conn.Write(SYNBytes)
    if err != nil {
        return false, err
    }

    reader := bufio.NewReader(conn)
    response, err := reader.ReadByte()
    if err != nil {
        return false, err
    }

    if response == socketio.SYNACKT.Value() {
        return true, nil
    } else {
        return false, nil
    }
}

func main() {
    // 定义扫描目标IP地址和端口范围
    ipAddress := "127.0.0.1"
    startPort := 1
    endPort := 100

    // 初始化结果
    results := make(map[int]bool)

    // 扫描每一个端口
    for port := startPort; port <= endPort; port++ {
        isOpen, err := synScan(ipAddress, port, 100)
        if err != nil {
            fmt.Println(err)
            continue
        }
        results[port] = isOpen
    }

    // 输出扫描结果
    for port, isOpen := range results {
        if isOpen {
            fmt.Printf("Port %d is open
", port)
        } else {
            fmt.Printf("Port %d is closed
", port)
        }
    }
}
로그인 후 복사

4. 요약

이 글에서는 Golang을 사용하여 SYN 스캐닝을 구현하는 방법을 소개합니다. Golang을 사용하여 SYN 스캐닝을 구현하면 효율성과 정확성이 향상되고 코드를 읽고 유지 관리할 수 있게 됩니다. 동시에 개발자는 멀티스레딩이나 멀티코루틴을 사용하여 더 많은 포트를 스캔하는 등 실제 필요에 따라 코드를 수정할 수 있으므로 더 넓은 범위의 애플리케이션 시나리오에 적합합니다.

위 내용은 Golang은 syn 스캐닝을 구현합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿