草庐IT

windows - 对于COM服务器和注册表项重定向,是否需要做文件路径重定向转换?

coder 2024-06-05 原文

如果标题不太准确,请原谅。

我在做一些与 COM 服务器和注册表重定向相关的事情时遇到了一些问题,我不太确定我的理解是否正确。希望任何人都可以分享一些关于它的信息。提前致谢。

基本上,在任何人可以使用它的服务之前,一个 COM 服务器已经在注册表中注册了。在 64 位 Windows 操作系统上,注册表中可能有 2 个可能的 View ,一个用于默认 View ,另一个用于 WOW64 View 。例如,第一个注册表项是:COMPUTER\HKEY_LOCAL_MACHINE\SOFTWARE\Classes\CLSID{GUID}\LocalServer32,另一个是:COMPUTER\HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Classes\CLSID{GUID}\LocalServer32。 并且取决于默认情况下可以读取其中任何一个的进程位数(64 位与 32 位),我们也可以使用 KEY_WOW64_64KEY 或 KEY_WOW64_32KEY(如:http://msdn.microsoft.com/en-us/library/windows/desktop/aa384129(v=vs.85).aspx)访问另一个备选注册表项。

我需要的是,我想通过读取注册表项来获取 LocalServer32 可执行文件,这可以工作。问题是,对于我读回的可执行文件路径,我是否需要根据从哪个 View 获取值来进行文件路径转换(以便获取正确的值)?比如从COMPUTER\HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Classes\CLSID{GUID}\LocalServer32获取文件路径,文件路径为:C:\Windows\System32\abc.exe,是否需要翻译路径到:C:\Windows\SysWow64\abc.exe?还是我需要将 C:\Program Files\abc.exe 转换为 C:\Program Files(x86).exe?

另一个问题是,如果对于COM的某个注册表项,两个 View 中设置的值不同(例如,一个是C:\Program Files\abc.exe,另一个是C:\Program Files (x86)\abc.exe),那么COM服务器启动时,svchost.exe怎么知道启动哪一个,C:\Program Files\abc.exe还是C:\Program Files(x86)\abc.exe ?有谁知道 svchost.exe 确定这一点的逻辑?如果存在则使用第一个,否则使用第二个?

非常感谢。

最佳答案

64 位版本的 Windows 已经具备了所有功能,您无需自行维护。您只需要在解决问题时牢记这些规则即可。

首先是注册表重定向器,它确保 32 位客户端程序不会意外读取包含仅适用于 64 位程序的配置信息的键。您已经知道,大多数 HKLM\Software 注册表访问都被重定向到 HKLM\Software\Wow6432Node。当注册 COM 服务器时,此重定向已经到位,32 位安装程序会自动重定向以将 key 写入 Wow6432Node。安装程序完全不知道 Wow6432Node 甚至存在。一切都自动结合在一起,安装程序被重定向,COM 服务器客户端也被重定向。您所关心的只是知道在哪里查看以验证安装是否正确完成,您必须使用 Regedit.exe 查看 HKLM\Software\Wow6432Node\Classes\CLSID 才能找到 key 。

文件重定向的工作方式大致相同,对 c:\windows\system32 的任何访问都被重定向到 c:\windows\syswow64,从 c:\program files 到 c:\program files (x86)。非常相似的是,32 位安装程序不必知道这方面的 bean,它可以简单地使用遗留的 32 位路径名。对于任何 32 位客户端程序都一样,它将以相同的方式重定向。您所关心的只是知道在哪里寻找文件来验证安装程序。

这只会在位数混合时出错,64 位程序读取注册表项或 32 位程序安装的文件。或者反过来。就像您的故障排除工具一样,例如 Explorer、Regedit 和 SysInternals 的 Process Monitor。一般来说,在 COM 中应该强烈避免的事情,大多数服务器都是进程内服务器,并且在 64 位进程中运行 32 位代码是不可能的。注册表和文件重定向器首先存在的最大原因。

关于windows - 对于COM服务器和注册表项重定向,是否需要做文件路径重定向转换?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22160577/

有关windows - 对于COM服务器和注册表项重定向,是否需要做文件路径重定向转换?的更多相关文章

  1. ruby - 在 Ruby 程序执行时阻止 Windows 7 PC 进入休眠状态 - 2

    我需要在客户计算机上运行Ruby应用程序。通常需要几天才能完成(复制大备份文件)。问题是如果启用sleep,它会中断应用程序。否则,计算机将持续运行数周,直到我下次访问为止。有什么方法可以防止执行期间休眠并让Windows在执行后休眠吗?欢迎任何疯狂的想法;-) 最佳答案 Here建议使用SetThreadExecutionStateWinAPI函数,使应用程序能够通知系统它正在使用中,从而防止系统在应用程序运行时进入休眠状态或关闭显示。像这样的东西:require'Win32API'ES_AWAYMODE_REQUIRED=0x0

  2. ruby - 具有身份验证的私有(private) Ruby Gem 服务器 - 2

    我想安装一个带有一些身份验证的私有(private)Rubygem服务器。我希望能够使用公共(public)Ubuntu服务器托管内部gem。我读到了http://docs.rubygems.org/read/chapter/18.但是那个没有身份验证-如我所见。然后我读到了https://github.com/cwninja/geminabox.但是当我使用基本身份验证(他们在他们的Wiki中有)时,它会提示从我的服务器获取源。所以。如何制作带有身份验证的私有(private)Rubygem服务器?这是不可能的吗?谢谢。编辑:Geminabox问题。我尝试“捆绑”以安装新的gem..

  3. ruby-on-rails - 启动 Rails 服务器时 ImageMagick 的警告 - 2

    最近,当我启动我的Rails服务器时,我收到了一长串警告。虽然它不影响我的应用程序,但我想知道如何解决这些警告。我的估计是imagemagick以某种方式被调用了两次?当我在警告前后检查我的git日志时。我想知道如何解决这个问题。-bcrypt-ruby(3.1.2)-better_errors(1.0.1)+bcrypt(3.1.7)+bcrypt-ruby(3.1.5)-bcrypt(>=3.1.3)+better_errors(1.1.0)bcrypt和imagemagick有关系吗?/Users/rbchris/.rbenv/versions/2.0.0-p247/lib/ru

  4. ruby-on-rails - s3_direct_upload 在生产服务器中不工作 - 2

    在Rails4.0.2中,我使用s3_direct_upload和aws-sdkgems直接为s3存储桶上传文件。在开发环境中它工作正常,但在生产环境中它会抛出如下错误,ActionView::Template::Error(noimplicitconversionofnilintoString)在View中,create_cv_url,:id=>"s3_uploader",:key=>"cv_uploads/{unique_id}/${filename}",:key_starts_with=>"cv_uploads/",:callback_param=>"cv[direct_uplo

  5. ruby - 在 Windows 机器上使用 Ruby 进行开发是否会适得其反? - 2

    这似乎非常适得其反,因为太多的gem会在window上破裂。我一直在处理很多mysql和ruby​​-mysqlgem问题(gem本身发生段错误,一个名为UnixSocket的类显然在Windows机器上不能正常工作,等等)。我只是在浪费时间吗?我应该转向不同的脚本语言吗? 最佳答案 我在Windows上使用Ruby的经验很少,但是当我开始使用Ruby时,我是在Windows上,我的总体印象是它不是Windows原生系统。因此,在主要使用Windows多年之后,开始使用Ruby促使我切换回原来的系统Unix,这次是Linux。Rub

  6. ruby-on-rails - 在 Rails 中调试生产服务器 - 2

    您如何在Rails中的实时服务器上进行有效调试,无论是在测试版/生产服务器上?我试过直接在服务器上修改文件,然后重启应用,但是修改好像没有生效,或者需要很长时间(缓存?)我也试过在本地做“脚本/服务器生产”,但是那很慢另一种选择是编码和部署,但效率很低。有人对他们如何有效地做到这一点有任何见解吗? 最佳答案 我会回答你的问题,即使我不同意这种热修补服务器代码的方式:)首先,你真的确定你已经重启了服务器吗?您可以通过跟踪日志文件来检查它。您更改的代码显示的View可能会被缓存。缓存页面位于tmp/cache文件夹下。您可以尝试手动删除

  7. ruby - 将 spawn() 的标准输出/标准错误重定向到 Ruby 中的字符串 - 2

    我想使用spawn(针对多个并发子进程)在Ruby中执行一个外部进程,并将标准输出或标准错误收集到一个字符串中,其方式类似于使用Python的子进程Popen.communicate()可以完成的操作。我尝试将:out/:err重定向到一个新的StringIO对象,但这会生成一个ArgumentError,并且临时重新定义$stdxxx会混淆子进程的输出。 最佳答案 如果你不喜欢popen,这是我的方法:r,w=IO.pipepid=Process.spawn(command,:out=>w,:err=>[:child,:out])

  8. Vscode+Cmake配置并运行opencv环境(Windows和Ubuntu大同小异) - 2

    之前在培训新生的时候,windows环境下配置opencv环境一直教的都是网上主流的vsstudio配置属性表,但是这个似乎对新生来说难度略高(虽然个人觉得完全是他们自己的问题),加之暑假之后对cmake实在是爱不释手,且这样配置确实十分简单(其实都不需要配置),故斗胆妄言vscode下配置CV之法。其实极为简单,图比较多所以很长。如果你看此文还配不好,你应该思考一下是不是自己的问题。闲话少说,直接开始。0.CMkae简介有的人到大二了都不知道cmake是什么,我不说是谁。CMake是一个开源免费并且跨平台的构建工具,可以用简单的语句来描述所有平台的编译过程。它能够根据当前所在平台输出对应的m

  9. 深度学习部署:Windows安装pycocotools报错解决方法 - 2

    深度学习部署:Windows安装pycocotools报错解决方法1.pycocotools库的简介2.pycocotools安装的坑3.解决办法更多Ai资讯:公主号AiCharm本系列是作者在跑一些深度学习实例时,遇到的各种各样的问题及解决办法,希望能够帮助到大家。ERROR:Commanderroredoutwithexitstatus1:'D:\Anaconda3\python.exe'-u-c'importsys,setuptools,tokenize;sys.argv[0]='"'"'C:\\Users\\46653\\AppData\\Local\\Temp\\pip-instal

  10. ruby - 我的 Ruby IRC 机器人没有连接到 IRC 服务器。我究竟做错了什么? - 2

    require"socket"server="irc.rizon.net"port="6667"nick="RubyIRCBot"channel="#0x40"s=TCPSocket.open(server,port)s.print("USERTesting",0)s.print("NICK#{nick}",0)s.print("JOIN#{channel}",0)这个IRC机器人没有连接到IRC服务器,我做错了什么? 最佳答案 失败并显示此消息::irc.shakeababy.net461*USER:Notenoughparame

随机推荐