64bit操作系统的重定向
64位操作系统下拷贝文件重定向问题
问题:installshield2009安装包在win 7 x64安装,需要把文件复制到windows\system32 下面 可是系统会自动复制到windows\syswow64下面,查一下来是文件自动转向
原因:64位操作系统有自动重定向功能,即使写死了拷贝到c:\windows\system32,你还是会沮丧地发现文件被拷贝到了c:\windows\syswow64下,简直令人抓狂
解决方法:只要在复制代码前加上Disable(WOW64FSREDIRECTION);就可以了
64位Windows的注册表重定向
错误现象:公司的产品在Install的时候找不到SQLServer,环境是Windows Server 2008 for X64, SQLServer 2008 X64, 装在一台机器上。
很简单就重现了。查看了下安装代码,似乎也没有问题,因为安装程序读取注册表SOFTWARE\\Microsoft\\Microsoft SQL Server\\100\\键下面的值来判断SQLServer 2008的路径等等信息,而这段代码用了好长时间,并且在测试机器的注册表中这个键是没有问题的,里面的路径信息也是正确的。
后来折腾了半天,发现问题原因是:产品的Installer是32位的程序。在64位的Windows系统中,如果某个程序是32位的,那么当它读取注册表的时候,Windows会自动来做重定向。所以,32位的Installer,在读取上面的那个键的时候,实际上读取的是SOFTWARE\\Wow6432Node\\Microsoft\\Microsoft SQL Server\\100\\ 这个键。而这个键是不存在的,自然就出错了。
解决方法也比较简单,加上读取注册表的参数REGDB_OPTION_WOW64_64KEY 就OK了。但是测试的时候又出现了问题。在64位Windows,32位的SQLServer 2008的时候该bug再次出现。
同样的查找了一下,猜测原因是32位的SQLServer 2008在安装的时候,安装程序自然是32位的。那么当安装程序在写注册表SOFTWARE\\Microsoft\\Microsoft SQL Server\\100\\ 的时候自动被系统重定向到了SOFTWARE\\Wow6432Node\\Microsoft\\Microsoft SQL Server\\100\\。而我们的程序因为启用了REGDB_OPTION_WOW64_64KEY,所以不会被重定向,自然读取就失败了。
实际在64位Windows Server中安装了一个32位的SQLServer,证实了这个猜测。
最后问题解决步骤:
1. 检测系统, 如果是32位的,直接读取。因为32位的Windows没有重定向这个说法。
这一步对于32位系统直接返回了,那么下面都是针对64位系统。
2. 启用REGDB_OPTION_WOW64_64KEY, 读取SOFTWARE\\Microsoft\\Microsoft SQL Server\\100\\. 因为当前系统是64位的,而且启动了这个参数,那么将直接读取这个Key。如果成功,说明系统中的是SQLServer 2008 64位;进行读取,返回;
3. 禁用REGDB_OPTION_WOW64_64KEY, 读取SOFTWARE\\Microsoft\\Microsoft SQL Server\\100\\. 因为当前系统是64位的,而Installer是32位的,所以系统要做自动的重定向,会重定向到SOFTWARE\\Wow6432Node\\Microsoft\\Microsoft SQL Server\\100\\。如果系统中安装了32位的SQLServer 2008,那么会在这个Key下面读出相应的值。如果读出了,返回;
4. 上面都没有读出,返回错误(SQLServer没找到)。