JavaScript 获取客户端计算机硬件及系统信息

作者:yemoo 来源:ajaxbbs 时间:2009-01-13 17:59:00 

因为我们现在的前端框架做性能优化,为了找到各个组件及框架的具体解析耗时,需要在框架中嵌入一个耗时测试工具,性能测试跟不同的计算机硬件配置有很大关系,因此有必要统计处测试机的硬件配置,本来开始是让测试人员自己输入,但考虑到这样比较繁琐,因此要想办法在程序中实现,因为此次的实现是用的JS。因此就有了我这篇文章。

在网上看到了一些文章和代码,觉得都不怎么好,其实JS访问硬件,只可能通过ActiveXObject,而且要用户计算机安全设置允许(这个没问题,毕竟测试人员就是我们自己)。网上很多人推荐使用WScript.Shell组件,我看了看,WSH对于硬件信息的读取很有限。于是另外寻找其他办法,后来看到可以通过WMI来实现,费了好大功夫,终于找到了自己需要获取的硬件信息。

对于WMI访问本地硬件及系统设置,本人推荐一个工具JSEDIT/VBSEDIT,提供了对WMI各个组件的访问示例,我们可以从中找到我们需要的东西。

先贴出来我的代码中关于硬件信息获取的一个函数:

//系统信息获取 
function getSysInfo(){ 
    var locator = new ActiveXObject ("WbemScripting.SWbemLocator");  
    var service = locator.ConnectServer(".");  
    //CPU信息 
    var cpu = new Enumerator (service.ExecQuery("SELECT * FROM Win32_Processor")).item();  
    var cpuType=cpu.Name,hostName=cpu.SystemName; 
    //内存信息 
    var memory = new Enumerator (service.ExecQuery("SELECT * FROM Win32_PhysicalMemory")); 
    for (var mem=[],i=0;!memory.atEnd();memory.moveNext()) mem[i++]={cap:memory.item().Capacity/1024/1024,speed:memory.item().Speed} 
    //系统信息 
    var system=new Enumerator (service.ExecQuery("SELECT * FROM Win32_ComputerSystem")).item(); 
    var physicMenCap=Math.ceil(system.TotalPhysicalMemory/1024/1024),curUser=system.UserName,cpuCount=system.NumberOfProcessors 
     
    return {cpuType:cpuType,cpuCount:cpuCount,hostName:hostName,curUser:curUser,memCap:physicMenCap,mem:mem} 

代码实现主要包括这几部分:

  1. 先通过new ActiveXObject ("WbemScripting.SWbemLocator"); 访问到WbemScripting对象。

  2. 通过locator.ConnectServer(".");连接我们本地电脑(.代表本地电脑,当然也可以访问其他计算机)。

  3. 通过service.ExecQuery("SELECT * FROM Win32_Processor")这个类似sql的语句(其实系统信息也是存储在计算中一个类似数据库的文件中)获取我们需要的对象的记录集。

  4. 通过new Enumerator来创建一个可枚举的对象,下面就可以遍历取信息了。


注意:运行的前提是要修改浏览器安全设置,“允许对未标记为可安全执行的ActiveX脚本的运行”,具体看下图,设置为允许或提示。


我这里主要取了CPU、内存及系统用户几个信息,大家利用WMI的API或者借助JSEDIT获取到更多的信息。

下面是一个运行的截图:

有兴趣的可以研究研究。

标签:客户端,硬件,系统,javascript
0
投稿

猜你喜欢

  • 详解如何在 Linux 中安装最新的 Python 3.6 版本

    2022-03-25 15:06:21
  • 理解 javascript 中的函数表达式与函数声明

    2024-04-23 09:08:26
  • SQLSERVER对索引的利用及非SARG运算符认识

    2024-01-14 23:24:34
  • 微信昵称带符号导致插入MySQL数据库时出错的解决方案

    2024-01-20 23:40:20
  • Python列表(list)所有元素的同一操作解析

    2021-05-06 22:56:31
  • mysql 查询当天、本周,本月,上一个月的数据

    2024-01-27 02:10:53
  • Python接口自动化系列之unittest结合ddt的使用教程详解

    2023-10-11 05:31:02
  • Navigator sendBeacon页面关闭也能发送请求方法示例

    2024-04-22 22:37:44
  • Pandas提高数据分析效率的13个技巧汇总

    2022-09-19 14:23:25
  • 分享9个好用的Python技巧

    2021-03-15 18:43:05
  • js随机永不重复数

    2011-04-25 19:26:00
  • Oracle数据库集复制方法浅议

    2023-07-16 16:33:49
  • 交互设计实用指南系列(3)—“有效性”之“适时帮助”

    2009-12-25 14:29:00
  • MySQL 常见错误分析与解决方法

    2024-01-16 12:36:50
  • Python实用库 PrettyTable 学习笔记

    2021-07-02 17:36:22
  • codeigniter发送邮件并打印调试信息的方法

    2024-05-13 09:57:03
  • “尊重”设计师?

    2009-03-23 18:14:00
  • 分享6 个值得收藏的 Python 代码

    2022-12-31 05:09:57
  • MySQL外键设置的方法实例

    2024-01-19 14:10:42
  • vue中beforeRouteLeave实现页面回退不刷新的示例代码

    2024-05-09 15:11:16
  • asp之家 网络编程 m.aspxhome.com