Java 獲得電腦網卡方法詳解 – JAVA編程語言程序開發技術文章

        現在我們的項目現在加入瞭身份驗證,通過收集客戶端的電腦的CPU編號、硬盤編號和網卡編號然後生成一個機器碼,然後使用這個機器碼作為身份標識, 驗證客戶端的合法性,我們的項目是RCP架構,所以使用瞭SWT Extension這樣的一個插件(國人開發,而且是BlogJava的會員),這樣比較方便,獲取CPU編號、硬盤編號倒是沒有什麼問題,獲取網卡信息的時候有些電腦居然采集不到信息,采集方式是這樣的:

int[] macs = Extension.GetMACAddress(0);
if(macs == null || macs.length ==0) {
    macs = Extension.GetMACAddress(1);
}
if(macs == null || macs.length ==0) {
    macs = Extension.GetMACAddress(2);
}
if(macs == null || macs.length ==0) {
    macs = Extension.GetMACAddress(3);
}
StringBuffer stringBuffer = new StringBuffer();
for (int i = 0; i < macs.length; i ) {
      stringBuffer.append(getHexString(macs[i], 2)
if (i != macs.length – 1)
        stringBuffer.append(“-“);
}
System.out.println(stringBuffer.toString.toUpperCase()););

        註意通過Extension.GetMACAddress()方法得到的網卡地址是一個十進制的數組,需要將他轉換成十六進制的,這樣才能和操作系統現在的信息一致。
        這種采集方式不是萬能,估計和操作環境有關系,我們這個項目的按照客戶端大概在4000臺電腦左右,大部分安裝的Windows 2000操作系統、Java運行環境是jre 6.0,通過分析發現有些電腦是雙網卡,我見得最多的一個電腦居然配置瞭9塊網卡(包括虛擬的和禁用掉的),在這種情況下SWT Extension 是無法正常工作瞭,網絡上也提供瞭其他的辦法比如使用

          String command = “cmd.exe /c ipconfig /all”;
          Process p = Runtime.getRuntime().exec(command);
          BufferedReader br = new BufferedReader(new InputStreamReader(p.getInputStream()));
          String line;
while ((line = br.readLine()) != null) {
            System.out.println(“line:” line);
if (line.indexOf(“Physical Address”) > 0) {
int index = line.indexOf(“:”);
              index = 2;
              address = line.substring(index);
break;
            }
          }
          br.close();

根據返回的輸入流從裡面解析信息,通過使用發現這種方式也不太管用!。這裡重點介紹第三種方式:通過JDK 6.0中的方法來獲取:

private static String getMac() {
try {
      Enumeration<NetworkInterface> el = NetworkInterface.getNetworkInterfaces();
while (el.hasMoreElements()) {
byte[] mac = el.nextElement().getHardwareAddress();
if (mac == null)
continue;
        StringBuilder builder = new StringBuilder();
for (byte b : mac) {
          builder.append(hexByte(b));
          builder.append(“-“);
        }
        builder.deleteCharAt(builder.length() – 1);
return builder.toString();
      }
    }
catch (Exception exception) {
      exception.printStackTrace();
    }
return null;
  }
這是JDK 6.0的新特性,可以支持多網卡配置,你隻需要判斷一下就行
        我的做法是將這三種方法同時使用:如果第一種方式獲取不到,換成第二種,第二種方法也無效的話,我就使用第三種,如果第三種方式仍然無效的話,隻能建議客戶重裝系統瞭:你還是升級到XP系統吧。

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。 必填欄位標示為 *