VBS 脚本不能运行 提示Windows无法访问指定设备路径或文件
昨天下载并且安装了Updater Application Block后,需要执行一个Deploy.vbs的文件,鄙人才疏学浅,这个小问题竟然也花费了我不少心机。
现在把结论共享一下。
首先,我的vbs文件关联已经被“豪杰”夺取了。我双击Deploy.vbs就会打开豪杰,比较郁闷。但是我用了打开方式,试了浏览器、cmd,都无济于事。
今天,我想到这个问题后,就有想法去Microsoft的News Group上去问一问。然后又去了CSDN的全文检索。果然很争气,我的关键字只是vbs,执行,就找到了一大堆我想要的东东。了解到用wscript.exe来执行这个文件。
在cmd里敲了wscript.exe Deploy.vbs,但是返回错误是 There is no script engine for file extension '.vbs'。这个时候我想到了google。果然搜到了不少有用的信息,其中第一条里我就找到了解决办法。 原因是我的vbs关联已经丢失了,必须显示指定。
cmd中敲入 wscript.exe //e:vbscript Deploy.vbs。果然成功!!!
如果不行可以使用
cscript.exe //e:vbscript Deploy.vbs
总结:用wscript.exe 执行类似vbs这类的脚本文件。如果文件关联丢失。可以用//e:vbscript.
附上我找到的很有帮助的文章。
一、什么是WSH?
WSH是Windows Scripting Host(Windows脚本主机)的缩略形式。WSH这个概念最早出现于Windows 98操作系统,是一个基于32 位 Windows 平台、并独立于语言的脚本运行环境。比如:你自己编写了一个脚本文件,如后缀为 .vbs 或 .js 的文件,然后在 Windows 下双击 并执行它,这时,系统就会自动调用一个适当的程序来对它进行解释并执行,而这个程序,就是 Windows Scripting Host,程序执行文件名为 Wscript.exe (若是在DOS命令提示符下,则为 Cscript.exe)。
想知道自己的机器上有没有WSH吗?查看一下你的机器里有没有“Wscipt.exe”或者“Cscript.exe”这两个文件就可以了。如果找到,恭 喜你!你已经安装了WSH。否则,自己手动安装吧:
在Windows 98环境下,WSH是作为操作系统的一个组件自动安装的,如果不慎丢失了这个组件,可以从依次打开“控制面板-->添加/删除程 序--〉Windows安装程序--〉附件”,然后将“Windows Scripting Host”前的划上“√”,再确定即可完成WSH组件的安装。
二、脚本语言与WSH的关系
大家知道,脚本语言(包括JavaScript和VBscript语言等)经常会被植入网页之中(其中包括 HTML 页面客户机端和 ASP 页面服务器端) 。对于植入 HTML 页面的脚本,其所需的解析引擎会由 IE 这样的网页浏览器载入;对于植入 ASP 页面的脚本,其所需的解析引擎会由 IIS( Internet Information Services)提供。而对于出现在 HTML 和 ASP 页面之外的脚本(它们常以独立的文件形式存在),就需要经由 WSH 来 处理了。需要说明的是:WSH 要想正常工作,还要安装IE 3.0 或更高版本的 IE,因为 WSH 在工作时会调用 IE 中的 VBScript 和 JavaScript 解析引擎。 [未结束][iduba_page]在这些被植于网页的脚本语言中,绝大多数是与网络安全无关的。但也有少数别有用心的好事 者,把一些严重危及网络安全的代码(我们常常称之为“恶意代码”,他们通常都要通过修改注册表达到“恶意”的目的!),混放在正常的 脚本之中,常常让我们防不胜防。但是,如果我们了解一点关于脚本语言的知识,这些“伎俩”都是非常容易识破的。还是让我们从几个简单 的实例开始吧……
三、WSH应用举例
WSH可以处理脚本程序,怎样阅读和编写WSH的脚本源文件呢?只要你有一点Basic(会VB的编程更好,呵呵)语言的基础,学会看懂WSH脚 本语言的程序并不是一件难事。去C:WINDOWSSAMPLESWSH目录以下将看看吧!里面提供了几类经典的脚本例子,而且分别提供了VBScript和 JavaScript两个版本,我们只要用记事本打开它们并仔细研究就不难学到一些基本的WSH应用。
你只需在记事本中依次输入以下每个实例中的代码,并保存为相应的“*.vbs”文件,双击这个文件,你就可以看到相应的效果了。
Windows无法访问指定设备路径或文件,您可能没有合适的权限访问这个项目
产生这个错误是因为你的系统分区采用ntfs分区格式,并且没有设置管理员权限.
解决办法:
1 查看c盘属性,切换到"安全"选项卡,然后点"添加",选择一个管理员账号,点"确定"。然后用这个管理员账号登陆即可(注销或重启电脑)
2 系统有病毒,并且有可能被修改了文件关联.解决办法就是杀毒和恢复文件关联.网上有专门修复文件关联的软件,搜索一下就好
3 系统中安装有安全软件,比如system safety monter软件
4 关闭杀毒软件和防火墙试试看事实不是可以打开
一个一个来,试试这个简便方法: 已解决>
右键点击X盘(X代表磁盘分区,如D盘、E盘......),“属性”——“安全”——选择你当前登陆的用户名,如“Administrator”等,将“Administrator的权限”下面的“允许”项目全部打钩,确定
另外还可以点击“添加”——“高级”——打开‘选择用户或组'对话框,——点选“立即查找”,将出现本机所有用户组,选择当前用户,“确定”,重复上面的步骤,“允许”项目全部打钩,再确定,应该就可以运行F盘所有的exe文件了
还不行的话,右键点击X盘(X代表磁盘分区,如D盘、E盘......),“属性”——“安全”——;选择“组或用户名称”里当前的登陆用户名,点“高级”——“所有者”——“目前该项目的所有者”栏目会显示“S-1-5-21-147001333-1580818891-1708537768-500”这一串;点选‘名称'里的用户名,勾选“替换子容器及对象的所有者”,点“确定”,等系统把它替换好了,就可以无限制的打开分区的exe文件了!
已在此解决
附加说明:NTFS格式的硬盘如果没有安全选项
打开一个文件夹,点菜单栏-工具-选项-查看-把“使用简单文件共享(推荐)”前的勾取消-确定。就有“安全”选项卡了。
————PS————
开始、运行cmd输入
assoc .exe=exefile〔assoc 跟.exe 之间要有空格〕
重新建立关联
如果是中毒请杀完先
或者这个办法
①进入系统盘windows文件夹,进入注册表所在的根目录。
②右键单击regedit.exe,选择重命名。(最好在DOS下改名,用ren命令)
①将文件后缀名“exe”改为“com”。
②双击打开注册表。
找到HKEY_CLASSES_ROOT\exefile\shell\open\command
双击默认键值。
输入“%1%*”,点“确定”。
2000及XP系统下均可使用这个办法搞定这种问题:
1、在 C: WINDOWS 下找到注册表编辑器 regedit.exe(蓝绿色图标)将.exe扩展名改成.com
(如果看不到扩展名就打开“我的电脑”→“工具”→“文件夹选项”→“查看”→下拉滚动条空选“隐藏已知文件类型的扩展名”。解决问题之后记得再把这个选项勾上,不然你以后会遇到你不知道的问题)
2、双击运行regedit.com
3、找到这个注册表分支[HKEY_CLASSES_ROOT exefile shell open command]
双击右侧的名称“默认”,将数值数据改为方括号中的内容["%1" %*]。关闭即可。
4、打开杀毒软件彻底查杀所有分区。
5、杀完毒之后将第一步中的regedit.com改回regedit.exe
6、收工!
电脑软硬件应用网站长编辑添加:
其它方法1:右击你的浏览器(Internet Explore)选属性,然后选择第四项“内容”。进入“发行者”。然后选择为受信任的发行者,把里面的选项全部删除掉 OK
其它方法2:文件和目录访问权限问题.如原操作系统对NTFS磁盘下的目录或文件设置严格的安全权限后,重装了操作系统前目录和文件权限没有恢复到默认,而且目录和文件和新的系统都保留时经常遇到这个问题,如果没有设置加密,一般还可以恢复,但如果设置加密基本恢复不了.方法:安全选项---高级----权限--添加现有用户---...继承....就可以
如有疑问可以随时和我讨论,给我发百度消息或者留言,望朋友们不吝赐教 ...O(∩_∩)O...
新发现一位网友的情况:(已解决)
添加Administrator的权限不凑效,以上办法都不管用
解决办法就是关掉瑞星实时监控,就一切都OK了!
估计某些系统文件感染了病毒,被瑞星阻止执行了,导致大多数exe不能正常运行
此种情况建议彻底杀毒,或者重装系统 【 {其他杀毒软件的情况类似} 】
您可能感兴趣的文章:- Mysql5.7在windows7下my.ini文件加载路径及数据位置修改方法
- c语言获取当前工作路径的实现代码(windows/linux)
- Windows server 2008 iis7/iis7.5启用父路径的方法
- windows与linux 路径正则写法
- windows下控制面版中各个项目的绝对路径
- Windows下修改iTunes备份路径 的方法