2

我们有一个奇怪且非常罕见的问题,即当我们的产品运行时人们无法注销 Windows 服务器。该系统是多应用程序,所有MFC/C++。这些应用程序是从管理服务运行的,因此它们可以在注销后继续存在。多年来,它在世界各地的大量安装中运行良好。

我编写了一个测试应用程序来枚举所有窗口,向它们发送 WM_QUERYENDSESSION 消息,并在它返回 FALSE 时停止。该测试是在德国的这些罕见的问题重现的案例之一上运行的。它似乎总是一个不可见的 IME(输入法编辑器)窗口,它是有罪的一方,但 IME 窗口始终属于我们的 MFC 应用程序之一。我想我可以通过调用 ImmDisableIME (-1) 来解决单个应用程序的问题。但我要找的是...

(a) 如果有人有一种配置方法来解决这个问题,那么我们就不必修改所有国家/地区的所有应用程序的所有版本——这是一项艰巨的工作。

(b) 首先为什么会发生这种情况。为什么我们没有创建的 IME 窗口会决定用户无法注销?

(c) 有没有其他人见过这个?苦难喜欢陪伴,你知道的。

如前所述,目前它正在德国的一台机器上发生。当然,我们不能在任何版本的 Windows 上进行复制。呸。

4

2 回答 2

2

微软似乎在使用不同版本的 IME 时遇到了其中一些问题。我发现了一些相对较旧的更新。您的客户正在运行什么操作系统,他们是否安装了 Office 版本?是否可以确定在您的情况下创建 IME 窗口的模块的文件名和版本?

这是 Office 2003 中与 IME 相关的更新:

微软已知错误 870774

关闭 Windows 时,消息框需要 30 秒才能关闭

当您尝试关闭具有 Office 2003 框架的基于日语 Windows 2000 的计算机,该框架用于支持安装高级文本服务,而无需先关闭所有打开的程序,您会收到每个打开的程序的消息框。单击“结束”时,关闭每个消息框大约需要 30 秒,然后 Windows 才能关闭。

  文件名 版本
   ----------------------
   Msctf.dll 5.1.2409.39
   Msimtf.dll 5.1.2409.39
   输入.cpl 5.1.2409.39
   Sptip.dll 5.1.2409.39

这是与 Windows XP IME 相关的更新:

微软已知错误 811147

Windows Messenger 在关机期间挂起并出现终止程序对话框

   日期时间版本大小文件名
   -------------------------------------------------- --
   2003 年 1 月 17 日 15:36 8.1.4008.0 57,400 Cplexe.exe
   2003 年 1 月 17 日 15:34 8.1.4008.0 335,917 Imjp81.ime
   2003 年 2 月 6 日 13:56 8.1.4008.0 827,438 Imjp81k.dll
   2003 年 2 月 6 日 13:56 8.1.4008.0 360,494 Imjpcic.dll
   2003 年 2 月 6 日 13:56 8.1.4008.0 716,857 Imjpcus.dll
   2003 年 2 月 6 日 13:56 8.1.4008.0 81,977 Imjpdct.dll
   2003 年 1 月 22 日 09:52 8.1.4008.0 307,258 Imjpdct.exe
   2003 年 1 月 17 日 15:36 8.1.4008.0 155,706 Imjpdsvr.exe
   2003 年 1 月 17 日 15:36 196,666 Imjpinst.exe
   2003 年 1 月 17 日 15:36 8.1.4008.0 208,953 Imjpmig.exe
   2003 年 1 月 17 日 15:36 8.1.4008.0 233,528 Imjprw.exe
   2003 年 1 月 17 日 15:36 8.1.4008.0 262,201 Imjputy.exe
   2003 年 2 月 6 日 13:56 8.1.4008.0 274,490 Imjputyc.dll
   2002 年 11 月 14 日 10:01 5.3.10.0 4,608 Spmsg.dll
于 2009-10-15T00:29:26.413 回答
0

另一个建议:

如果您知道哪个窗口有问题并且每次都是同一个窗口,您可以尝试对窗口进行子分类并直接处理 WM_QUERYSESSIONEND 消息。这将 IME 窗口排除在外,应该是一个相当可维护的解决方案。

于 2009-09-30T16:39:19.670 回答