我就废话不多说了,大家还是直接看代码吧~
package mainimport ('fmt''os/exec''strings''github.com/safchain/ethtool')func main() {baseNicPath := '/sys/class/net/'cmd := exec.Command('ls', baseNicPath)buf, err := cmd.Output()if err != nil {//fmt.Println('Error:', err)return}output := string(buf)for _, device := range strings.Split(output, 'n') {if len(device) > 1 {fmt.Println(device)ethHandle, err := ethtool.NewEthtool()if err != nil {panic(err.Error())}defer ethHandle.Close()stats, err := ethHandle.LinkState(device)if err != nil {panic(err.Error())}fmt.Printf('LinkName: %s LinkState: %dn', device, stats)}}}©
补充:GO 语言取得 Ethernet 类型的网卡地址
在 C# 中取得 Ethernet 类型的网卡地址在 C# 中,因为有 NetworkInterface .NetworkInterfaceType == NetworkInterfaceType.Ethernet 所以,很容易在代码中进行判断。
public static PhysicalAddress GetMacAddress(){ foreach (NetworkInterface nic in NetworkInterface.GetAllNetworkInterfaces()) { // Only consider Ethernet network interfaces if (nic.NetworkInterfaceType == NetworkInterfaceType.Ethernet) // nic.OperationalStatus == OperationalStatus.Up { return nic.GetPhysicalAddress(); } } return null;}在 GO 中的处理办法
搜索百度百十回,没有找到答案,无奈,搜索 net 包的源码,找到蛛丝马迹,在未公开的方法中,找到一个类型的判断语句。net/interface_windows.go 中,有 case windows.IF_TYPE_ETHERNET_CSMACD 的类型判断。
再查找 IF_TYPE_ETHERNET_CSMACD 的资料,正是这里所需要的。
参考:IP_INTERFACE_NAME_INFO_W2KSP1 structure
于是,将需要的部分复制出来加以改造,得到 IsEthernet 方法,结合 net 包中已有的方法,参数使用 net.Interface 的 Index 来使用。
完整代码如下:
package machine import ( 'errors' 'net' 'os' 'strings' 'syscall' 'unsafe' 'golang.org/x/sys/windows') func GetMACAddress() (string, error) { netInterfaces, err := net.Interfaces() if err != nil { panic(err.Error()) } mac, macerr := '', errors.New('no valid mac address') for i := 0; i < len(netInterfaces); i++ { if (netInterfaces[i].Flags&net.FlagLoopback) == 0 && strings.Contains(netInterfaces[i].Flags.String(), 'broadcast') { index := netInterfaces[i].Index if isEthernet(index) { mac = netInterfaces[i].HardwareAddr.String() return mac, nil } } } return mac, macerr} // 根据网卡接口 Index 判断其是否为 Ethernet 网卡func isEthernet(ifindex int) bool { aas, err := adapterAddresses() if err != nil { return false } result := false for _, aa := range aas { index := aa.IfIndex if ifindex == int(index) { switch aa.IfType { case windows.IF_TYPE_ETHERNET_CSMACD: result = true } if result { break } } } return result} // 从 net/interface_windows.go 中复制过来func adapterAddresses() ([]*windows.IpAdapterAddresses, error) { var b []byte l := uint32(15000) // recommended initial size for { b = make([]byte, l) err := windows.GetAdaptersAddresses(syscall.AF_UNSPEC, windows.GAA_FLAG_INCLUDE_PREFIX, 0, (*windows.IpAdapterAddresses)(unsafe.Pointer(&b[0])), &l) if err == nil { if l == 0 { return nil, nil } break } if err.(syscall.Errno) != syscall.ERROR_BUFFER_OVERFLOW { return nil, os.NewSyscallError('getadaptersaddresses', err) } if l <= uint32(len(b)) { return nil, os.NewSyscallError('getadaptersaddresses', err) } } var aas []*windows.IpAdapterAddresses for aa := (*windows.IpAdapterAddresses)(unsafe.Pointer(&b[0])); aa != nil; aa = aa.Next { aas = append(aas, aa) } return aas, nil}
以上为个人经验,希望能给大家一个参考,也希望大家多多支持乐呵呵网。如有错误或未考虑完全的地方,望不吝赐教。