友情提示:此篇文章大約需要閱讀 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.255
IP: 192.160.0.255
這樣就會出現問題,可以看到按照簡單的分段對比,很明顯校驗不透過,但是這個 IP 還是存在在 IP 段中,方案只能針對統一分段下規則的IP段才可以區分。
PLAN B 轉整型對別
IP 地址可以轉換為整數,可以將 IP 範圍化整為 整數範圍進行排查。
這種方式只需要將授為範圍內的地址轉換為整數,就可以將 IP 排查在外了。
程式碼
以下是示例程式碼:
package main
import (
"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
}
本作品採用《CC 協議》,轉載必須註明作者和本文連結