功能:可以快速扫描指定端口范围,ip地址范围。将扫描结果保存到本地!先来体验一下运行后的效果:

image.png
image.png

帮助信息

scanPort -h 
Options:
  -h    帮助信息
  -ip string
        ip地址 例如:-ip 192.168.0.1-255 或直接输入域名 xs25.cn (default "127.0.0.1")
  -n int
        进程数 例如:-n 10 (default 100)
  -p string
        端口号范围 例如:-p 80,81,88-1000 (default "80")
  -path string
        日志地址 例如:-path log (default "log")
  -t int
        超时时长(毫秒) 例如:-t 200 (default 200)

例1:指定端口号扫描,如我们要扫描xs25.cn这台服务的开放端口,使用1000个协程进行

scanport -p 80,81,88-3306 -ip xs25.cn -n 1000

例2:指定IP范围扫描,如我们扫描 192.168.0.1-255 网段的端口 80-10000

scanPort -ip 192.168.0.1-255 -p 80-10000

注:程序扫描完后开放端口放在log目录中,如想更改目录名请加 -path 参数来指定

具体代码如下

详细代码见:https://github.com/xs25cn/scanPort
main.go 文件:

package main
import (
    "flag"
    "fmt"
    "os"
    "github.com/xs25cn/scanPort/lib"
    "github.com/xs25cn/scanPort/scan"
    "time"
)

var (
    startTime = time.Now()
    ip        = flag.String("ip", "127.0.0.1", "ip地址 例如:-ip=192.168.0.1-255 或直接输入域名 xs25.cn")
    port      = flag.String("p", "80-1000", "端口号范围 例如:-p=80,81,88-1000")
    path      = flag.String("path", "log", "日志地址 例如:-path=log")
    timeout   = flag.Int("t", 200, "超时时长(毫秒) 例如:-t=200")
    process   = flag.Int("n", 100, "进程数 例如:-n=10")
    h         = flag.Bool("h", false, "帮助信息")
)
//go run main.go -h
func main() {
    flag.Parse()
    //帮助信息
    if *h == true {
        lib.Usage("scanPort version: scanPort/1.10.0\n Usage: scanPort [-h] [-ip ip地址] [-n 进程数] [-p 端口号范围] [-t 超时时长] [-path 日志保存路径]\n\nOptions:\n")
        return
    }

    fmt.Printf("========== Start %v ip:%v,port:%v ==================== \n", time.Now().Format("2006-01-02 15:04:05"), *ip, *port)

    //创建目录
    lib.Mkdir(*path)

    //初始化
    scanIP := scan.ScanIp{
        Debug:   true,
        Timeout: *timeout,
        Process: *process,
    }
    ips, err := scanIP.GetAllIp(*ip)
    if err != nil {
        fmt.Println(err.Error())
        return
    }
    //扫所有的ip
    fileName := *path + "/" + *ip + "_port.txt"
    for i := 0; i < len(ips); i++ {
        ports := scanIP.GetIpOpenPort(ips[i], *port)
        if len(ports) > 0 {
            f, err := os.OpenFile(fileName, os.O_CREATE|os.O_WRONLY|os.O_APPEND, 0666)
            if err != nil {
                if err := f.Close(); err != nil {
                    fmt.Println(err)
                }
                continue
            }
            var str = fmt.Sprintf("%v ip:%v,开放端口:%v \n", time.Now().Format("2006-01-02 15:04:05"), ips[i], ports)
            if _, err := f.WriteString(str); err != nil {
                if err := f.Close(); err != nil {
                    fmt.Println(err)
                }
                continue
            }
        }
    }
    fmt.Printf("========== End %v 总执行时长:%.2fs ================ \n", time.Now().Format("2006-01-02 15:04:05"), time.Since(startTime).Seconds())

}

scan.go 文件