網絡上百度了下大致都是如下做法:
addrs, err := net.InterfaceAddrs()
if err != nil {
return false
}
for _, address := range addrs {
if ipnet, ok := address.(*net.IPNet); ok && !ipnet.IP.IsLoopback() {
if ipnet.IP.To4() != nil {
gInnerIP = ipnet.IP.String()
return true
}
}
}
這種實現方式忽略了一個網卡可用性的問題,導致獲取出來的IP可能不一定是想要的。需要通過判斷net.FlagUp標誌進行確認,排除掉無用的網卡。優化後的實現方式:
netInterfaces, err := net.Interfaces()
if err != nil {
fmt.Println("net.Interfaces failed, err:", err.Error())
return false
}
for i := 0; i < len(netInterfaces); i++ {
if (netInterfaces[i].Flags & net.FlagUp) != 0 {
addrs, _ := netInterfaces[i].Addrs()
for _, address := range addrs {
if ipnet, ok := address.(*net.IPNet); ok && !ipnet.IP.IsLoopback() {
if ipnet.IP.To4() != nil {
fmt.Println(ipnet.IP.String())
return true
}
}
}
}
}
return false