zoukankan      html  css  js  c++  java
  • 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没找到)。

  • 相关阅读:
    4月7日工作日志
    5月4日工作日志
    4月7日工作日志
    4月1日工作日志
    3月31日工作日志
    3月31日工作日志
    对元素绑定事件方法
    css实现垂直居中的各种方法
    纯css写一个switch开关
    弹性盒模型flex布局
  • 原文地址:https://www.cnblogs.com/BeyondTechnology/p/1857881.html
Copyright © 2011-2022 走看看