Я знаю, что мы можем получить MAC-адрес пользователя через IE (объекты ActiveX).
Есть ли способ получить MAC-адрес пользователя с помощью JavaScript?
Я знаю, что мы можем получить MAC-адрес пользователя через IE (объекты ActiveX).
Есть ли способ получить MAC-адрес пользователя с помощью JavaScript?
Ответы:
Я согласен со всеми предыдущими ответами, что это было бы уязвимостью конфиденциальности / безопасности, если бы вы могли сделать это непосредственно из Javascript. Я могу думать о двух вещах:
Быстрый и простой ответ - нет.
Javascript - это язык достаточно высокого уровня, и он не имеет доступа к такого рода информации.
Нет, вы не можете получить MAC-адрес в JavaScript, в основном потому, что MAC-адрес однозначно определяет работающий компьютер, поэтому это может быть уязвимостью безопасности.
Теперь, если все, что вам нужно, это уникальный идентификатор, я предлагаю вам создать его самостоятельно, используя некоторый криптографический алгоритм, и сохранить его в файле cookie.
Если вам действительно нужно знать MAC-адрес компьютера, И вы разрабатываете для внутренних приложений, то я предлагаю вам использовать для этого внешний компонент: ActiveX для IE, XPCOM для Firefox (устанавливается как расширение).
Если это для приложения интрасети и все клиенты используют DHCP, вы можете запросить DHCP-сервер для получения MAC-адреса для данного IP-адреса.
Я искал ту же проблему и наткнулся на следующий код.
Как получить MAC-адрес клиента (Интернет):
Чтобы получить MAC-адрес клиента, мы можем полагаться только на JavaScript и контроль Active X от Microsoft. Это работает только в IE, если Active X включен для IE. Поскольку ActiveXObject недоступен в Firefox, он не работает с Firefox и отлично работает в IE.
Этот сценарий предназначен только для IE:
function showMacAddress() {
var obj = new ActiveXObject("WbemScripting.SWbemLocator");
var s = obj.ConnectServer(".");
var properties = s.ExecQuery("SELECT * FROM Win32_NetworkAdapterConfiguration");
var e = new Enumerator(properties);
var output;
output = '<table border="0" cellPadding="5px" cellSpacing="1px" bgColor="#CCCCCC">';
output = output + '<tr bgColor="#EAEAEA"><td>Caption</td><td>MACAddress</td></tr>';
while (!e.atEnd()) {
e.moveNext();
var p = e.item();
if (!p) continue;
output = output + '<tr bgColor="#FFFFFF">';
output = output + '<td>' + p.Caption; +'</td>';
output = output + '<td>' + p.MACAddress + '</td>';
output = output + '</tr>';
}
output = output + '</table>';
document.getElementById("box").innerHTML = output;
}
showMacAddress();
<div id='box'></div>