纯Java获得本地MAC地址
来源:互联网 发布:js比较两个数组的差异 编辑:程序博客网 时间:2024/05/21 16:58
转的,当做笔记
import java.net.*;public class Ipconfig{ public static void main(String[] arguments) throws Exception{ InetAddress ia = InetAddress.getLocalHost();//获取本地IP对象 System.out.println("MAC ......... "+getMACAddress(ia)); } //获取MAC地址的方法 private static String getMACAddress(InetAddress ia)throws Exception{ //获得网络接口对象(即网卡),并得到mac地址,mac地址存在于一个byte数组中。 byte[] mac = NetworkInterface.getByInetAddress(ia).getHardwareAddress(); //下面代码是把mac地址拼装成String StringBuffer sb = new StringBuffer(); for(int i=0;i<mac.length;i++){ if(i!=0){ sb.append("-"); } //mac[i] & 0xFF 是为了把byte转化为正整数 String s = Integer.toHexString(mac[i] & 0xFF); sb.append(s.length()==1?0+s:s); } //把字符串所有小写字母改为大写成为正规的mac地址并返回 return sb.toString().toUpperCase(); } }
另一篇类似文章
//获取所有网卡的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);
}
//获取所有网卡的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);
}
然后,我们用如下测试代码,看一下测试结果
view plaincopy to clipboardprint?
List<String> list = getAllMac();
for (String mac : list) {
System.out.println(mac);
}
List<String> list = getAllMac();
for (String mac : list) {
System.out.println(mac);
}
输出结果如下:
view plaincopy to clipboardprint?
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: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方法,如下:
view plaincopy to clipboardprint?
private static String parseByte(byte b) {
String s = "00"+Integer.toHexString(byte0);
return s.substring(s.length() - 2);
}
private static String parseByte(byte b) {
String s = "00"+Integer.toHexString(byte0);
return s.substring(s.length() - 2);
}
输出结果就变了:
view plaincopy to clipboardprint?
00:18:8b:cc:xx:e3
00:00:00:00:00:e0
00:50:xx:c0:00:01
00:50:xx:c0:00:08
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()返回此接口是否是虚拟接口
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);
}
//获取所有网卡的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);
}
然后,我们用如下测试代码,看一下测试结果
view plaincopy to clipboardprint?
List<String> list = getAllMac();
for (String mac : list) {
System.out.println(mac);
}
List<String> list = getAllMac();
for (String mac : list) {
System.out.println(mac);
}
输出结果如下:
view plaincopy to clipboardprint?
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: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方法,如下:
view plaincopy to clipboardprint?
private static String parseByte(byte b) {
String s = "00"+Integer.toHexString(byte0);
return s.substring(s.length() - 2);
}
private static String parseByte(byte b) {
String s = "00"+Integer.toHexString(byte0);
return s.substring(s.length() - 2);
}
输出结果就变了:
view plaincopy to clipboardprint?
00:18:8b:cc:xx:e3
00:00:00:00:00:e0
00:50:xx:c0:00:01
00:50:xx:c0:00:08
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获得本地MAC地址
- 纯Java获得本地MAC地址
- 纯Java获得本地MAC地址
- 纯Java获得本机MAC地址
- java怎样获得本地MAC地址
- Java 获得MAC地址
- java获得MAC地址
- Java获得本地IP地址
- JAVA获得网卡MAC地址
- java 获得网卡MAC地址
- vb获得本地和远程的MAC地址 (网卡地址)
- vb获得本地和远程的MAC地址 (网卡地址)
- 纯Java代码获取网卡MAC地址
- java纯代码获取mac地址
- Java获取本地机器MAC地址
- 获得本地IP地址
- 获得本地IP地址
- 获得网卡MAC地址
- 注解@PostConstruct与@PreDestroy讲解及实例
- logic:present 和 logic:empty标签
- Chrome 扩展 资料收集
- 基于hibernate的分页程序的实现(后台)
- Struts2(三) 接受请求参数
- 纯Java获得本地MAC地址
- sql语句的编程手册 SQL PLUS
- struts标签使用举例--logic篇
- 2012年“Openstack中国行”活动总结与回顾
- MyEclipse与Eclipse区别是什么?
- advanced installer制作windows软件安装界面
- 关于Android使用proguard进行代码混淆
- 命令模式
- 2>&1 的用法说明。