如何利用NetworkInterface获取服务器MAC地址

 更新时间:2013年08月30日 09:44:52   作者:  
今天介绍一种通用的跨平台的操作方式,那就是JDK自带的NetworkInterface接口,该接口在JDK1.4已经出现,但是功能比较少,JDK1.6之后新增了不少新功能,比较不错

在很多时候,我们需要获得服务器硬件信息(比如MAC地址),常用的有几种的方式:
•使用命令行程序获得硬盘信息,然后通过Runtime.getRuntime().exec获得输出流,然后通过字符串分析获得MAC地址
•编译本地程序,然后通过JNI调用

以上两种方式都需要区分不同的操作系统平台,分别编码,比较麻烦,比如
• windows平台需要使用iptables /all命令
•linux平台需要使用ifconfig命令

今天介绍一种通用的跨平台的操作方式,那就是JDK自带的NetworkInterface接口,该接口在JDK1.4已经出现,但是功能比较少,JDK1.6之后新增了不少新功能,比较不错。

具体功能大家可以参考API文档,这里主要介绍一下如何获得服务器MAC地址,代码如下,有注释,不多讲。

复制代码 代码如下:

//获取所有网卡的MAC地址       
public static List<String> getAllMac() {
                List<String> list = new ArrayList<String>();
                try {
                        Enumeration<NetworkInterface> e = NetworkInterface.getNetworkInterfaces();// 返回所有网络接口的一个枚举实例
                        while (e.hasMoreElements()) {
                                NetworkInterface network = e.nextElement();// 获得当前网络接口
                                if (network != null) {
                                        if (network.getHardwareAddress() != null) {
                                                // 获得MAC地址
                                                //结果是一个byte数组,每项是一个byte,我们需要通过parseByte方法转换成常见的十六进制表示
                                                byte[] addres = network.getHardwareAddress();
                                                StringBuffer sb = new StringBuffer();
                                                if (addres != null && addres.length > 1) {
                                                        sb.append(parseByte(addres[0])).append(":").append(
                                                                        parseByte(addres[1])).append(":").append(
                                                                        parseByte(addres[2])).append(":").append(
                                                                        parseByte(addres[3])).append(":").append(
                                                                        parseByte(addres[4])).append(":").append(
                                                                        parseByte(addres[5]));
                                                        list.add(sb.toString());
                                                }
                                        }
                                } else {
                                        System.out.println("获取MAC地址发生异常");
                                }
                        }
                } catch (SocketException e) {
                        e.printStackTrace();
                }
                return list;
        }
           //格式化二进制
        private static String parseByte(byte b) {
                int intValue = 0;
                if (b >= 0) {
                        intValue = b;
                } else {
                        intValue = 256 + b;
                }
                return Integer.toHexString(intValue);
        }

然后,我们用如下测试代码,看一下测试结果
复制代码 代码如下:

                List<String> list = getAllMac();
                for (String mac : list) {
                        System.out.println(mac);
                }

输出结果如下:
复制代码 代码如下:

0:18:8b:cc:xx:e3
0:0:0:0:0:0:0:e0
0:50:xx:c0:0:1
0:50:xx:c0:0:8

大家发现,"0:18:8b:cc:xx:e3",只有一个0,看起来很是别扭啊,我们不妨修订一下parseByte方法,如下:
复制代码 代码如下:

        private static String parseByte(byte b) {
                 String s = "00"+Integer.toHexString(byte0);
                 return s.substring(s.length() - 2);
        }

输出结果就变了:
复制代码 代码如下:

00:18:8b:cc:xx:e3
00:00:00:00:00:e0
00:50:xx:c0:00:01
00:50:xx:c0:00:08

这样就看起来舒服多了嘛,是吧?
另外,NetworkInterface接口还提供了如下方法,大家可以参考一下。

•String displayName() 获取网络接口的显示名称
•int getMTU()返回此接口的最大传输单元(Maximum Transmission Unit,MTU)
•String getName()获取此网络接口的名称
•boolean isLoopback()返回此网络接口是否是回送接口
•boolean isPointToPoint()返回此网络接口是否是点对点接口
•boolean isUp()返回此网络接口是否已经开启并运行
•boolean isVirtual()返回此接口是否是虚拟接口

相关文章

  • 基于Java实现记事本功能

    基于Java实现记事本功能

    这篇文章主要为大家详细介绍了基于Java实现记事本功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-12-12
  • Netty分布式行解码器逻辑源码解析

    Netty分布式行解码器逻辑源码解析

    这篇文章主要为大家介绍了Netty分布式行解码器逻辑源码解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-03-03
  • JAVA二叉树的基本操作

    JAVA二叉树的基本操作

    这篇文章主要介绍了JAVA二叉树的基本操作DEMO,想要详情了解的小伙伴请接着看下文吧
    2021-08-08
  • Spring Boot 集成 Swagger2构建 API文档

    Spring Boot 集成 Swagger2构建 API文档

    这篇文章主要介绍了Spring Boot 集成 Swagger2构建 API文档,通过使用 Swagger,我们只需要按照它所给定的一系列规范去定义接口以及接口的相关信息,然后它就能帮我们自动生成各种格式的接口文档,方便前后端开发者进行前后端联调,下文需要的朋友可以参考一下
    2022-03-03
  • 最值得Java开发者收藏的网站

    最值得Java开发者收藏的网站

    这篇文章主要为大家分享了最值得Java开发者收藏的11个网站,帮助Java开发者提升编程能力
    2016-11-11
  • java Object wait方法详细介绍

    java Object wait方法详细介绍

    这篇文章主要介绍了java Object wait方法详细介绍的相关资料,需要的朋友可以参考下
    2017-02-02
  • java 算法之快速排序实现代码

    java 算法之快速排序实现代码

    这篇文章主要介绍了java 算法之快速排序实现代码的相关资料,需要的朋友可以参考下
    2017-05-05
  • java实现系统捕获异常发送邮件案例

    java实现系统捕获异常发送邮件案例

    这篇文章主要为大家详细介绍了java实现系统捕获异常发送邮件案例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-11-11
  • JavaSE学习之内部类及常用API

    JavaSE学习之内部类及常用API

    这篇文章主要介绍了JavaSE中的内部类和几个常用的API,文中的示例代码介绍详细,对我们学习JavaSEI有一定的帮助,感兴趣的小伙伴可以跟随小编一起学习一下
    2021-12-12
  • 如何解决maven报错:不知道这样的主机问题

    如何解决maven报错:不知道这样的主机问题

    这篇文章主要介绍了如何解决maven报错:不知道这样的主机问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2025-04-04

最新评论