什么是 ActiveX 控件?
ActiveX 控件广泛用于 Internet。它们可以通过提供视频、动画内容等来增加浏览的乐趣。不过,这些程序可能出问题或者向您提供不需要的内容。在某些情况下,这些程序可被 用来以您不允许的方式从计算机收集信息、破坏您的计算机上的数据、在未经您同意的情况下在您的计算机上安装软件或者允许他人远程控制您的计算机。考虑到这 些风险,您应该在完全信任发行商的情况下才安装这些程序。
当 Windows 阻止 ActiveX 控件的安装时,您应该做什么?
您可能不应该安装该 ActiveX 控件。安装 Windows 阻止的 ActiveX 控件是极为冒险的事情。如果 Internet Explorer 安全设置处于默认级别,并且 ActiveX 控件没有有效的数字签名,Windows 就会阻止该 ActiveX 控件的安装。
有效的数字签名可确认发行商的标识(分发文件的公司、网站或个人),并确认文件自签名以后没有被篡改过这一事实。如果文件没有有效的数字签名, 您就无法确定文件是否真的来自它所声明的来源,或者它是否没有被篡改过(例如,可能会有病毒插入控件中)。除非您信任发行商,并且知道文件打开后内容会是 安全的,否则,就不应该打开文件。
ActiveXObject对象使用说明:
 
JavaScript中ActiveXObject对象是启用并返回 Automation 对象的引用。使用方法:
newObj = new ActiveXObject( servername.typename[, location])
ActiveXObject 对象语法有这些部分:
其中newObj是必选项。要赋值为 ActiveXObject 的变量名。
servername是必选项。提供该对象的应用程序的名称。
typename是必选项。要创建的对象的类型或类。
location是可选项。创建该对象的网络服务器的名称。
Automation服务器至少提供一类对象,例如字处理应用程序可能提供应用程序对象、文档对象和工具栏对象。
例如要创建Excel的Application和Sheet对象,代码如下:

var ExcelApp = new ActiveXObject("Excel.Application");
var ExcelSheet = new ActiveXObject("Excel.Sheet")

旦对象被创建,就可以用定义的对象变量在代码中的引用它。下面我们将通过一个例子来看看对对象和方法的引用,通过对象变量 ExcelSheet
访问新对象的属性和方法和其他 Excel 对象,包括 Application 对象和 ActiveSheet.Cells 集合。代码如下:

1 ExcelSheet.Application.Visible = true;
2 ExcelSheet.ActiveSheet.Cells(1,1).Value = "This is column A, row 1";
3 ExcelSheet.SaveAs("C:\\TEST.XLS");
4 ExcelSheet.Application.Quit();
 
 


面我们来看看怎样创建远程服务器中创建对象,但是这有一个前提就是要将Internet安全性关闭。要在远程网络计算机创建对象,可以将该计算机的名称传
递给 ActiveXObject 的 servername 参数。该名称与共享名的机器名部分相同。比如共享名为
"\\myserver\public" 的网络,servername 是 "myserver"。另外,可以用 DNS 格式或 IP 地址指定
servername。下面的代码返回在名为 "myserver" 的远程网络计算机上运行的 Excel 实例的版本号:

1 function GetAppVersion() {
2     var XLApp = new ActiveXObject("Excel.Application", "MyServer");
3     return(XLApp.Version);
4 }
如果指定的远程服务器不存在或找不到时将会发生错误。
  1. javascript取得机器名,用户名,读写注册表,启动应用程序
  2. //javascript有个特殊的对象ActiveXObject,通过它可以访问windows的本地文件系统和应用程序,
  3. 比如:有的时候我们需要得到用户的机器名,用户名,得到某个文件的信息,或者读写注册表,或者启动计算器、outlook等应用程序。
  4. 下面是一些常用的方法,每个都经过了测试。
  5. <script language="JavaScript">
  6. //取得机器名,登录域及登录用户名
  7. function getusername()
  8. {
  9. var WshNetwork = new ActiveXObject("WScript.Network");
  10. alert("Domain = " + WshNetwork.UserDomain);
  11. alert("Computer Name = " + WshNetwork.ComputerName);
  12. alert("User Name = " + WshNetwork.UserName);
  13. }
  14. //取得系统目录
  15. function getprocessnum()
  16. {
  17. var pnsys=new ActiveXObject("WScript.shell");
  18. pn=pnsys.Environment("PROCESS");
  19. alert(pn("WINDIR"));
  20. }
  21. //返回系统中特殊目录的路径
  22. function getspecialfolder()
  23. {
  24. var mygetfolder=new ActiveXObject("WScript.shell");
  25. if(mygetfolder.SpecialFolders("Fonts")!=null)
  26. {
  27. alert(mygetfolder.SpecialFolders("Fonts"));
  28. }
  29. }
  30. //取得磁盘信息 传入参数如:getdiskinfo('c')
  31. function getdiskinfo(para)
  32. {
  33. var fs=new ActiveXObject("scripting.filesystemobject");
  34. d=fs.GetDrive(para);
  35. s="卷标:" + d.VolumnName;
  36. s+="------" + "剩余空间:" + d.FreeSpace/1024/1024 + "M";
  37. s+="------" + "磁盘序列号:" + d.serialnumber;
  38. alert(s)
  39. }
  40. //取得系统目录
  41. function getprocessnum()
  42. {
  43. var pnsys=new ActiveXObject("WScript.shell");
  44. pn=pnsys.Environment("PROCESS");
  45. alert(pn("WINDIR"));
  46. }
  47. //启动计算器
  48. function runcalc()
  49. {
  50. var calc=new ActiveXObject("WScript.shell");
  51. calc.Run("calc");
  52. }
  53. //读取注册表中的值
  54. function readreg()
  55. {
  56. var myreadreg=new ActiveXObject("WScript.shell");
  57. try{
  58. alert(myreadreg.RegRead             ("HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Run\\NeroCheck"));
  59. }
  60. catch(e)
  61. {
  62. alert("读取的值不存在!");
  63. }
  64. }
  65. //写注册表
  66. function writereg()
  67. {
  68. var mywritereg=new ActiveXObject("WScript.shell");
  69. try{
  70. mywritereg.RegWrite("HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Run\\MyTest","c:\\mytest.exe");
  71. alert("写入成功!");
  72. }
  73. catch(e)
  74. {
  75. alert("写入路径不正确!");
  76. }
  77. }
  78. //删除注册表
  79. function delreg()
  80. {
  81. var mydelreg=new ActiveXObject("WScript.shell");
  82. if(confirm("是否真的删除?"))
  83. {
  84. try{
  85. mydelreg.RegDelete("HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Run\\MyTest");
  86. alert("删除成功!");
  87. }
  88. catch(e)
  89. {
  90. alert("删除路径不正确");
  91. }
  92. }
  93. }
  94. //取得文件信息    调用方式如:getfileinfo('c:\\test.pdf')
  95. function getfileinfo(para)
  96. {
  97. var myfile=new ActiveXObject("scripting.filesystemobject");
  98. var fi=myfile.GetFile(para);
  99. alert("文件类型:"+fi.type+"文件大小:"+fi.size/1024/1024+"M"+"最后一次访问时间:"+fi.DateLastAccessed);
  100. }
  101. //取得客户端的信息
  102. function clientInfo()
  103. {
  104. strClientInfo="availHeight=      "+window.screen.availHeight+"\n"+
  105. "availWidth=      "+window.screen.availWidth+"\n"+
  106. "bufferDepth=      "+window.screen.bufferDepth+"\n"+
  107. "colorDepth=      "+window.screen.colorDepth+"\n"+
  108. "colorEnable=      "+window.navigator.cookieEnabled+"\n"+
  109. "cpuClass=      "+window.navigator.cpuClass+"\n"+
  110. "height=      "+window.screen.height+"\n"+
  111. "javaEnable=      "+window.navigator.javaEnabled()+"\n"+
  112. "platform=      "+window.navigator.platform+"\n"+
  113. "systemLanguage=      "+window.navigator.systemLanguage+"\n"+
  114. "userLanguage=      "+window.navigator.userLanguage+"\n"+
  115. "width=      "+window.screen.width;
  116. alert(strClientInfo);
  117. }
  118. </script>
  119. //另存为excel文件并写入值
  120. function saveas(){
  121. var ExcelApp = new ActiveXObject("Excel.Application");
  122. var ExcelSheet = new ActiveXObject("Excel.Sheet")
  123. ExcelSheet.Application.Visible = true;
  124. ExcelSheet.ActiveSheet.Cells(1,1).Value = "This is column A, row 1";
  125. ExcelSheet.SaveAs("C:\\TEST.XLS");
  126. ExcelSheet.Application.Quit();
  127. alert('ok');
  128. }

ActiveXObject函数详解(转)的更多相关文章

  1. ActiveXObject函数详解

    什么是 ActiveX 控件? ActiveX 控件广泛用于 Internet.它们可以通过提供视频.动画内容等来增加浏览的乐趣.不过,这些程序可能出问题或者向您提供不需要的内容.在某些情况下,这些程 ...

  2. ActiveXObject函数详解(转自http://eyesinthesky.iteye.com/blog/1560033)

    什么是 ActiveX 控件? ActiveX 控件广泛用于 Internet.它们可以通过提供视频.动画内容等来增加浏览的乐趣.不过,这些程序可能出问题或者向您提供不需要的内容.在某些情况下,这些程 ...

  3. malloc 与 free函数详解<转载>

    malloc和free函数详解   本文介绍malloc和free函数的内容. 在C中,对内存的管理是相当重要.下面开始介绍这两个函数: 一.malloc()和free()的基本概念以及基本用法: 1 ...

  4. NSSearchPathForDirectoriesInDomains函数详解

    NSSearchPathForDirectoriesInDomains函数详解     #import "NSString+FilePath.h" @implementation ...

  5. JavaScript正则表达式详解(二)JavaScript中正则表达式函数详解

    二.JavaScript中正则表达式函数详解(exec, test, match, replace, search, split) 1.使用正则表达式的方法去匹配查找字符串 1.1. exec方法详解 ...

  6. Linux C popen()函数详解

    表头文件 #include<stdio.h> 定义函数 FILE * popen( const char * command,const char * type); 函数说明 popen( ...

  7. kzalloc 函数详解(转载)

    用kzalloc申请内存的时候, 效果等同于先是用 kmalloc() 申请空间 , 然后用 memset() 来初始化 ,所有申请的元素都被初始化为 0. view plain /** * kzal ...

  8. Netsuite Formula > Oracle函数列表速查(PL/SQL单行函数和组函数详解).txt

    PL/SQL单行函数和组函数详解 函数是一种有零个或多个参数并且有一个返回值的程序.在SQL中Oracle内建了一系列函数,这些函数都可被称为SQL或PL/SQL语句,函数主要分为两大类: 单行函数 ...

  9. jQuery.attr() 函数详解

    一,jQuery.attr()  函数详解: http://www.365mini.com/page/jquery-attr.htm 二,jQuery函数attr()和prop()的区别: http: ...

随机推荐

  1. 微信web开发工具

    http://mp.weixin.qq.com/wiki/10/e5f772f4521da17fa0d7304f68b97d7e.html#.E4.B8.8B.E8.BD.BD.E5.9C.B0.E5 ...

  2. wireshark 包过滤

    tcp.port == 443 or udp.port==443 or tcp.port==53 or udp.port==53

  3. HDU2544-最短路(最短路模版题目)

    Problem Description 在每年的校赛里,所有进入决赛的同学都会获得一件很漂亮的t-shirt.但是每当我们的工作人员把上百件的衣服从商店运回到赛场的时候,却是非常累的!所以现在他们想要 ...

  4. javaWEB总结(7):HttpServlet和HttpServletRequest

    前言:HttpServletRequest对象封装了客户端进行HTTP协议请求时的所有信息,HttpServletRequest继承了ServletRequest,所以和ServletRequest一 ...

  5. Spring 框架理论基础

    一. IOC 控制反转 概念解释:当我需要一个资源时,容器已经帮我准备好,我只需要接受就可以. // 加载 IOC 容器 ApplicationContext ac = new ClassPathXm ...

  6. java类的初始化

    转载:http://blog.csdn.net/moreevan/article/details/6968718 我们知道一个类(class)要被使用必须经过装载,连接,初始化这样的过程.下面先对这三 ...

  7. 如何更改mysql可执行路径及更改mysql数据库文件路径

    一.如何更改服务中MySQL的可执行文件路径: 解决方法:到注册表里HKEY_LOCAL_MECHINE---SYSTEM ---CurrentControlSet 更改查找一. MySQL项值,然后 ...

  8. 用jQuery写的最简单的表单验证

    近几天完成了关于我们项目的最简单的表单验证,是用jQuery写的,由于之前也一直没学过jQuery,所以自己也是一直处于边摸索边学习的阶段,经过这一段时间的学习,通过查资料啥的,也发现了学习jQuer ...

  9. JavaScript高级程序设计:第五章

    引用类型 一.object类型: 创建object实例的方式有两种.第一种是使用new操作符后跟Object构造函数,如下所示: var  person = new  Object(): person ...

  10. hdu_5805_NanoApe Loves Sequence(xjb搞)

    题目链接:hdu_5805_NanoApe Loves Sequence 题意: 给你n个数,现在要删一个数,删每个数的概率是一样的,现在问你删一个值后的相邻数绝对值最大差的期望是多少,因为担心精度误 ...