情谊提醒:此篇文章大概须要浏览 3分钟21秒,不足之处请多指教,感激你的浏览。 订阅本站

背景

近期做了一个需要,是检测某个 IP 是否在若干 IP 段内,做固定地点 IP 筛查,满足特定业务需要。

解决方案

PLAN A 点分十进制范畴辨别

简略来讲,就是将 IPv4 原有的四段,别离比照 IP 地址,查看每一段是否在 IP 段范畴内,能够用于段管制在每一个特定段 0 ~ 255 内筛选,例如:

192.123.1.0 ~ 192.123.156.255 

这样的比拟标准的特定段能够实现简略的筛选,然而问题来了,不规则的间断 IP 段怎么排除? 如下:

IP段:192.168.1.0 ~ 192.172.3.255IP: 192.160.0.255

这样就会呈现问题,能够看到依照简略的分段比照,很显著校验不通过,然而这个 IP 还是存在在 IP 段中,计划只能针对对立分段下规定的IP段才能够辨别。

PLAN B 转整型对别

IP 地址能够转换为整数,能够将 IP 范畴化整为 整数范畴进行排查。

这种形式只须要将授为范畴内的地址转换为整数,就能够将 IP 排查在外了。

代码

以下是示例代码:

package mainimport (    "fmt"    "strconv"    "strings")func main() {    ipVerifyList := "192.168.1.0-192.172.3.255"    ip := "192.170.223.1"    ipSlice := strings.Split(ipVerifyList, `-`)    if len(ipSlice) < 0 {        return    }    if ip2Int(ip) >= ip2Int(ipSlice[0]) && ip2Int(ip) <= ip2Int(ipSlice[1]) {        fmt.Println("ip in iplist")        return    }    fmt.Println("ip not in iplist")}func ip2Int(ip string) int64 {    if len(ip) == 0 {        return 0    }    bits := strings.Split(ip, ".")    if len(bits) < 4 {        return 0    }    b0 := string2Int(bits[0])    b1 := string2Int(bits[1])    b2 := string2Int(bits[2])    b3 := string2Int(bits[3])    var sum int64    sum += int64(b0) << 24    sum += int64(b1) << 16    sum += int64(b2) << 8    sum += int64(b3)    return sum}func string2Int(in string) (out int) {    out, _ = strconv.Atoi(in)    return}