最近遇到一个需求,医院要求呼叫中心账号必须对应MAC地址,也就是说该MAC地址必须和呼叫中心账号对应才可使用,这可就难道我了,这需求就要求每次都判断用户登录的电脑MAC地址是否有呼叫中心账号,当然只针对IE浏览器,毕竟其他浏览器是直接就给禁止此功能的。

那么首先问题一:如何才能通过页面访问得到本地MAC地址

问题二:每台电脑上都有多个MAC地址,那么应该选用哪一个MAC地址

MAC地址是每台电脑链接网络的物理地址,是唯一标识,想要从浏览器获取电脑的信息,那么就需要ActiveX,所以其他浏览器是没有办法通过js获取MAC地址的。

方法一:(推荐)需要客户端设置将服务器地址加入受信任站点

<html>

<head>

<title>获取客户端MAC地址</title>

</head>

<body>

<object classid="CLSID:76A64158-CB41-11D1-8B02-00600806D9B6" id="locator" style="display:none;visibility:hidden"></object>

<object classid="CLSID:75718C9A-F029-11d1-A1AC-00C04FB6C223" id="foo" style="display:none;visibility:hidden"></object>

<form name="myForm">

<br/>MAC地址:<input type="text" name="macAddress">

<br/>IP地址:<input type="text" name="ipAddress">

<br/>主机名:<input type="text" name="hostName">

</form>

</body>

</html>

<script language="javascript">

var sMacAddr="";

var sIPAddr="";

var sDNSName="";

var service = locator.ConnectServer();

service.Security_.ImpersonationLevel=3;

service.InstancesOfAsync(foo, 'Win32_NetworkAdapterConfiguration');

</script>

<script FOR="foo" EVENT="OnObjectReady(objObject,objAsyncContext)" LANGUAGE="JScript">

if(objObject.IPEnabled != null && objObject.IPEnabled != "undefined" && objObject.IPEnabled == true){

if(objObject.IPEnabled && objObject.IPAddress(0) !=null && objObject.IPAddress(0) != "undefined")

sIPAddr = objObject.IPAddress(0);

if(objObject.MACAddress != null &&objObject.MACAddress != "undefined")

sMacAddr = objObject.MACAddress;

if(objObject.DNSHostName != null &&objObject.DNSHostName != "undefined")

sDNSName = objObject.DNSHostName;

}

</script>

<script FOR="foo" EVENT="OnCompleted(hResult,pErrorObject, pAsyncContext)" LANGUAGE="JScript">

myForm.macAddress.value=sMacAddr;

myForm.ipAddress.value=sIPAddr;

myForm.hostName.value=sDNSName;

</script>

方法二:

<!DOCTYPE html>

<html>

<head>

<title>获取电脑硬件信息</title>

<meta name="keywords" content="keyword1,keyword2,keyword3">

<meta name="description" content="this is my page">

<meta name="content-type" content="text/html; charset=GBK">

</head>

<body>

<script id="clientEventHandlersJS" language="javascript" charset="utf-8">

http://www.w3school.com.cn/htmldom/dom_obj_navigator.asp

/******************************************以上为浏览器信息,以下为pc信息************************************************/ try {  var locator = new ActiveXObject ("WbemScripting.SWbemLocator");

var service = locator.ConnectServer(".");

//获取网络连接信息

function ipinfo(){

var properties = service.ExecQuery("SELECT * FROM Win32_NetworkAdapterConfiguration Where IPEnabled=TRUE");

var e = new Enumerator (properties);

var info="<table border=1>";

info+="<tr bgcolor='#CDEDED' style='font-weight: bold;' >

<td width='450'>网络连接信息:</td></tr>";

var i=1;

for (;!e.atEnd();e.moveNext ()){

var p = e.item ();

info+="<tr style='color: red'><td >MAC地址"+i+":" + p.MACAddress + "</td></tr>";     info+="<tr style='color: red'><td >IP地址"+i+":" + p.IPAddress(0) + "</td></tr>";     i++;    }

info+="</table>";    return info;   }

function pcInfo() {//所有信息

var info=ipinfo();

/* info+=disk();     info+=raminfo();

info+=mainBoard();

info+=ipinfo();

info+=keyBoardInfo();

info+=RomInfo();

info+=softDisk(); */       document.getElementById('elInfo').innerHTML=info;

return info;   } } catch (e) {  document.write(e); }

/******************************************以上为pc信息************************************************/

</script>

</head>

<body >   <!--  <INPUT id="Button1" type="button" value="浏览器所有信息" name="Button1" language=javascript onclick="allinfo()">  -->

<INPUT id="Button1" type="button" value="客户端pc信息" name="Button1" language=javascript onclick="pcInfo()">

<div id="elInfo" >

</div>   </body> </html>

最新文章

  1. 利用Simple-RTMP-Server(SRS)来进行直播
  2. react native windows开发环境搭建(一)
  3. python基础(三元运算+深浅拷贝+函数参数)
  4. Android的两种上下文的区别
  5. 九度OJ 1505 两个链表的第一个公共结点 【数据结构】
  6. Spring MVC框架理解
  7. poj3415
  8. tomcat 支持https
  9. 【SQL学习笔记】排名开窗函数,聚合开窗函数(Over by)
  10. Python3.6_安装numpy
  11. jquery获取焦点和失去焦点事件代码
  12. Jenkins简明入门(二) -- 利用Jenkins完成Python程序的build、test、deployment
  13. 初识Redis系列之四:.net使用Redis存储数据
  14. 头部——MimeHeaders
  15. HI258摄像头旋转配置问题
  16. 在coding或者github建立个人站点域名绑定
  17. Hadoop简单介绍
  18. 【JVM】-NO.111.JVM.1 -【JDK11 HashMap详解-1-hash()剖析】
  19. 真机*Appium
  20. Luogu3676 小清新数据结构题 动态点分治

热门文章

  1. node async基础1
  2. OVS + kernel datapath 的安装
  3. 深入探索C++对象模型(五)
  4. MyEclipse解决SVN同步冲突问题conflict in the working copy obstructs the current operation
  5. JavaScript中的数组
  6. python每天一个小练习-强壮的密码
  7. MVC中控制器当中需要绑定SelectList,也就是所谓的DropDownList
  8. python 标准库 -- unittest
  9. Cordova各个插件使用介绍系列(二)—$cordovaBarcodeScanner扫描二维码与生成二维码
  10. 关于MATLAB处理大数据坐标文件2017526