登录
首页 >  Golang >  Go教程

Golang基础端口扫描器实现教程

时间:2025-09-04 08:48:38 319浏览 收藏

**Golang实现基础端口扫描器教程:快速入门与实践** 想知道如何用Golang编写一个端口扫描器吗?本文将带你一步步学习,利用Go的`net`包,通过`DialTimeout`函数检测端口连接状态,并结合`goroutine`实现并发扫描,大幅提升扫描效率。文章提供详细代码示例,包括`scanPort`函数用于检测单个端口,`portScan`函数实现并发扫描并输出开放端口。完整程序可扫描`scanme.nmap.org`的指定端口,并统计扫描耗时。无论你是Go语言新手还是有一定经验的开发者,都能通过本教程快速掌握Golang端口扫描器的核心原理与实现方法,为网络安全学习和实践打下坚实基础。但请注意,端口扫描需在授权范围内进行,切勿用于非法用途。

答案:使用Go的net包实现端口扫描,通过DialTimeout检测连接,结合goroutine并发扫描多端口。示例代码包含scanPort检测单个端口,portScan并发扫描并输出开放端口,完整程序可扫描scanme.nmap.org的指定端口并统计耗时。

如何使用Golang实现一个基本的端口扫描器

实现一个基本的端口扫描器在Golang中非常直接,主要利用net包提供的网络功能。你可以通过尝试与目标IP的特定端口建立TCP连接,判断端口是否开放。下面是一个简单但实用的端口扫描器实现步骤和代码示例。

1. 理解端口扫描的基本原理

端口扫描的核心是向目标主机的某个端口发起连接请求。如果连接成功(无错误返回),说明该端口处于开放状态;如果连接失败或超时,则认为端口关闭或被防火墙拦截。

在Go中,使用net.DialTimeout()可以设置连接超时,避免程序卡住。

2. 编写基础端口扫描函数

以下是一个扫描单个端口的函数示例:

func scanPort(protocol, host string, port int, timeout time.Duration) bool {
    address := fmt.Sprintf("%s:%d", host, port)
    conn, err := net.DialTimeout(protocol, address, timeout)
    if err != nil {
        return false
    }
    conn.Close()
    return true
}

这个函数尝试连接指定的主机和端口,如果成功则返回true,否则返回false

3. 并发扫描多个端口

为了提高效率,可以使用Go的goroutine并发扫描多个端口。通过sync.WaitGroup控制并发流程,使用channel收集结果。

func portScan(host string, ports []int, timeout time.Duration) {
    var wg sync.WaitGroup
    result := make(chan int)
// 启动结果收集goroutine
go func() {
    for openPort := range result {
        fmt.Printf("Port %d is open\n", openPort)
    }
}()

// 并发扫描每个端口
for _, port := range ports {
    wg.Add(1)
    go func(p int) {
        defer wg.Done()
        if scanPort("tcp", host, p, timeout) {
            result <- p
        }
    }(port)
}

wg.Wait()
close(result)

}

4. 完整可运行示例

将以上部分组合成一个完整的程序:

package main

import ( "fmt" "net" "sync" "time" )

func scanPort(protocol, host string, port int, timeout time.Duration) bool { address := fmt.Sprintf("%s:%d", host, port) conn, err := net.DialTimeout(protocol, address, timeout) if err != nil { return false } conn.Close() return true }

func portScan(host string, ports []int, timeout time.Duration) { var wg sync.WaitGroup result := make(chan int)

go func() {
    for openPort := range result {
        fmt.Printf("Port %d is open\n", openPort)
    }
}()

for _, port := range ports {
    wg.Add(1)
    go func(p int) {
        defer wg.Done()
        if scanPort("tcp", host, p, timeout) {
            result <- p
        }
    }(port)
}

wg.Wait()
close(result)

}

func main() { target := "scanme.nmap.org" // 可公开测试的目标 portList := []int{22, 80, 443, 8080}

fmt.Printf("Scanning %s...\n", target)
start := time.Now()

portScan(target, portList, 2*time.Second)

fmt.Printf("Scan completed in %v\n", time.Since(start))

}

这段代码会并发扫描指定的几个端口,并输出开放的端口。你也可以将portList扩展为1-1024的范围来扫描常用端口。

基本上就这些。这个扫描器虽然简单,但已经具备基本功能。你可以在此基础上添加功能,比如支持端口范围输入、扫描协议选择、结果保存到文件等。注意:扫描非自己控制的主机可能违反法律或服务条款,请确保在授权范围内使用。

以上就是《Golang基础端口扫描器实现教程》的详细内容,更多关于的资料请关注golang学习网公众号!

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>