最近工作上遇到的一个问题,记录一下。怕以后再遇到的时候又忘了。
在64位Windows系统下,有两个系统目录:C:\Windows\system32 和 C:\Windows\SysWOW64。C:\Windows\system32目录下存放的是64位的程序,而C:\Windows\SysWOW64目录下存放的是32位的程序。如果在一个32位的应用程序内执行脚本内的系统指令时,Windows系统会自动重定向到存放32位系统程序的系统目录(也就是C:\Windows\SysWOW64目录)下查找系统指令对应的程序(exe文件等)。 如果没有找到对应的可执行文件,则控制台窗口会报出“‘xxx’不是内部或外部命令,也不是可运行的程序或批处理文件”的错误信息,即命令执行失败。
在64位Windows系统中,有的系统命令是既有32位可执行文件也有64位可执行文件,也就是在C:\Windows\system32 和 C:\Windows\SysWOW64目录下都有对应的程序,比如ping命令;而有的系统命令则只有64位的可执行文件,也就是只在C:\Windows\system32目录下有对应的可执行文件,比如nbtstat命令。
因此,在64位的Windows系统下,32位的应用程序中,执行bat文件内的nbtstat指令时,Windows系统会自动重定向到C:\Windows\SysWOW64目录下寻找nbtstat.exe文件并执行,但是由于C:\Windows\SysWOW64目录下并没有nbtstat.exe文件,最终导致nbtstat命令执行失败。
解决办法:
在nbtstat指令前加上路径C:\Windows\sysnative\。(不能直接加C:\Windows\SysWOW64,这样的话系统还是会重定向到C:\Windows\system32目录)
原因:
C:\Windows\sysnative\目录是64位Windows系统下的一个虚拟目录。在资源管理器、命令行中都无法识别这个目录,但是,在脚本文件内部,Windows系统会自动将这个目录重定向到C:\Windows\system32目录。这样的话,在32位的应用程序中就能访问存放64位程序的系统目录C:\Windows\system32了。)
但并不是所有的系统命令都需要做这样的处理(即指令前加C:\Windows\sysnative\)。比如,ping命令,它们有对应的32位和64位可执行程序,在这种情况下就不需要做处理。
参考链接: https://scottiestech.info/2009/06/20/calling-a-32-bit-system-command-from-a-script-in-x64-windows/