xml地图|网站地图|网站标签 [设为首页] [加入收藏]

软件专题

当前位置:美高梅游戏网站 > 软件专题 > ShellExecuteEX打开iqy文件导致excel hang的原因分析

ShellExecuteEX打开iqy文件导致excel hang的原因分析

来源:http://www.gd-chuangmei.com 作者:美高梅游戏网站 时间:2019-10-03 11:38

1. 问题

try
{
美高梅游戏官网娱乐,fs = new StreamReader(new FileStream(path, FileMode.Open, FileAccess.Read), Encoding.GetEncoding("gb2312"));//正常读取文件,如果被excel程序独占的话,此时会抛出异常
}
catch(Exception e)
{
//抛出异常后,那么就可以拷贝此文件到临时文件夹下生成的一个随机文件中,然后读取此临时文件即可
string tempFile = Path.GetTempPath() + Path.GetRandomFileName();
美高梅游戏网站,File.Copy(path, tempFile);
fs = new StreamReader(new FileStream(tempFile, FileMode.Open, FileAccess.Read), Encoding.GetEncoding("gb2312"));
}

当在console中调用API ShellExecuteEx打开"test.iqy"文件时,发现excel会hang住,console退出后excel才会响应,但直接双击"test.iqy"是没有问题的,有意思的是这个情况只有在xp发生,在win7上没有这个问题。

 

2. 重现步骤

重现环境:XP sp3 / Office 2007(其他office版本应该也可以,没有测试)

1> 解压iqy_test.zip

2> 运行http_server.py(需先安装python)

3> 执行"shell_execute.exe test.iqy"

shell_execute.exe的主要code:

bool shell_execute_file(wstring file_path)
{
    SHELLEXECUTEINFOW shell_exec_info = { 0 };
    shell_exec_info.cbSize = sizeof(SHELLEXECUTEINFOW);
    shell_exec_info.fMask = SEE_MASK_NOCLOSEPROCESS | SEE_MASK_FLAG_NO_UI;
    shell_exec_info.hwnd = NULL;
    shell_exec_info.lpVerb = NULL;
    shell_exec_info.lpFile = file_path.c_str();
    shell_exec_info.lpParameters = NULL;
    shell_exec_info.lpDirectory = NULL;
    shell_exec_info.nShow = SW_SHOW;
    shell_exec_info.hInstApp = NULL;
    bool ret = ShellExecuteExW(&shell_exec_info);
    printf("process handle is %pn", shell_exec_info.hProcess);

    return ret;
}

 

3. 原因分析

3.1 excel hang在哪里?

3.1.1 用windbg附加到excel上,输入如下命令查看主线程hang住的地方

美高梅游戏网站 1

可以看到Excel hang在NtUserMessageCall()中,经过查询知,SendMessage()内部就是调用NtUserMessageCall()来发送消息的。

查看参数知excel调用NtUserMessageCall()类似如下:

NtUserMessageCall(HWND_BROADCAST, WM_DDE_INITIATE)

说明excel给所有顶层窗口发送一个WM_DDE_INITIATE消息,但是有窗口没有response

由此可以怀疑是由于console进程在和excel用DDE消息通信时,console没有响应excel发送的DDE消息,导致excel hang住

 

3.2 为了验证3.1.1的猜想,用API Monitor一下ShellExecuteEx

3.2.1 根据微软的文档可知,发送DDE消息除了WM_DDE_INITIATE和WM_DDE_ACK之外用的都是PostMessage

在API Monitor中搜索一下PostMessage的调用,果然搜到一条

美高梅游戏网站 2

call stack显示确实是ShellExecuteEx所调用

美高梅游戏网站 3

消息1000为WM_DDE_EXECUTE,Post窗口句柄为0x00310172。

本文由美高梅游戏网站发布于软件专题,转载请注明出处:ShellExecuteEX打开iqy文件导致excel hang的原因分析

关键词:

上一篇:没有了

下一篇:没有了