转: CreateProcessAsUser 0xC0000005访问冲突问题
- #include <WtsApi32.h>
- #pragma comment(lib, "WtsApi32.lib")
- bool MyImpersonateLoggedOnUser()
- {
- HANDLE hToken = NULL;
- DWORD dwConsoleSessionId = WTSGetActiveConsoleSessionId();
- if (WTSQueryUserToken(dwConsoleSessionId, &hToken))
- {
- if (ImpersonateLoggedOnUser(hToken))
- {
- // 保存Token
- WCHAR *szCmdLine = L"c:\\notepad.exe"; //错误在这里
- STARTUPINFO si;
- ZeroMemory(&si, sizeof(STARTUPINFO));
- si.cb = sizeof(STARTUPINFO);
- si.lpDesktop = L"winsta0\\default";
- PROCESS_INFORMATION pi;
- ZeroMemory(&pi, sizeof(pi));
- // hToken为当前登陆用户的令牌
- LPVOID lpEnvBlock = NULL;
- BOOL bEnv = false;// CreateEnvironmentBlock(&lpEnvBlock, hToken, FALSE);
- DWORD dwFlags = CREATE_NEW_CONSOLE;
- if (bEnv)
- {
- dwFlags |= CREATE_UNICODE_ENVIRONMENT;
- }
- // 环境变量创建失败仍然可以创建进程,但会影响到后面的进程获取环境变量内容
- bool bRet = CreateProcessAsUser(
- hToken,
- NULL,
- szCmdLine,
- NULL,
- NULL,
- FALSE,
- dwFlags,
- bEnv ? lpEnvBlock : NULL,
- NULL,
- &si,
- &pi);
- int a = GetLastError();
- // 使用完毕需要释放环境变量的空间
- if (bEnv)
- {
- DestroyEnvironmentBlock(lpEnvBlock);
- }
- WaitForSingleObject(pi.hProcess, INFINITE);
- return true;
- }
- }
- return false;
- }
如果把“c:\\notepad.exe"定义到栈或者全局变量就不存在此问题了。
修改后的代码:
- #include <WtsApi32.h>
- #pragma comment(lib, "WtsApi32.lib")
- bool MyImpersonateLoggedOnUser()
- {
- HANDLE hToken = NULL;
- DWORD dwConsoleSessionId = WTSGetActiveConsoleSessionId();
- if (WTSQueryUserToken(dwConsoleSessionId, &hToken))
- {
- if (ImpersonateLoggedOnUser(hToken))
- {
- // 保存Token
- WCHAR szCmdLine[] = L"c:\\notepad.exe"; //改变了szCmdLine的地址空间
- STARTUPINFO si;
- ZeroMemory(&si, sizeof(STARTUPINFO));
- si.cb = sizeof(STARTUPINFO);
- si.lpDesktop = L"winsta0\\default";
- PROCESS_INFORMATION pi;
- ZeroMemory(&pi, sizeof(pi));
- // hToken为当前登陆用户的令牌
- LPVOID lpEnvBlock = NULL;
- BOOL bEnv = false;// CreateEnvironmentBlock(&lpEnvBlock, hToken, FALSE);
- DWORD dwFlags = CREATE_NEW_CONSOLE;
- if (bEnv)
- {
- dwFlags |= CREATE_UNICODE_ENVIRONMENT;
- }
- // 环境变量创建失败仍然可以创建进程,但会影响到后面的进程获取环境变量内容
- bool bRet = CreateProcessAsUser(
- hToken,
- NULL,
- szCmdLine,
- NULL,
- NULL,
- FALSE,
- dwFlags,
- bEnv ? lpEnvBlock : NULL,
- NULL,
- &si,
- &pi);
- int a = GetLastError();
- // 使用完毕需要释放环境变量的空间
- if (bEnv)
- {
- DestroyEnvironmentBlock(lpEnvBlock);
- }
- WaitForSingleObject(pi.hProcess, INFINITE);
- return true;
- }
- }
- return false;
- }
转: CreateProcessAsUser 0xC0000005访问冲突问题的更多相关文章
- C++中一个0xC0000005访问冲突问题
在冯.诺依曼结构CPU(如i386,ARM A8,A9)的保护模式或者哈佛结构(如8051, ARM M0,.. M3)的CPU下,C++编译器将放置常量的内存设置为只读模式或者放入只读内存中,如果出 ...
- [精品]CAD批量处理工具
需要此工具请Q:3567 618 336 CAD批量处理工具是基于AutoCAD二次开发的批处理插件.将程序加载到CAD中,使用自定义的Lisp代码就可对多个文档进行批量操作. 1.文件说明 CAD ...
- __stdcall __cdecl 引起的程序崩溃
崩溃弹出的截图如下 看到0xC0000005, 访问冲突的问题, 九成九是内存访问违规, 比如访问了已经释放的指针, 又或者是离开函数时栈被破坏之类. 找了一下午一直没有头绪, 好在有一份可以执行的源 ...
- 问题解决——使用CriticalSection后 0xXXXXXXXX处最可能的异常: 0xC0000005: 写入位置 0x00000014 时发生访问冲突
================声明===================== 本文原创,转载请保持文章的完整性(含本声明),并显要的著名作者和出处. 本文链接:http://blog.csdn.ne ...
- 启动MFC程序的时候报错:0xC0000005: 读取位置 0x00000000 时发生访问冲突
此程序的结构是 MouseCap.h #pragma once #include <afxwin.h> class MouseCapApp : public CWinApp { publi ...
- 0xC0000005: 读取位置 0x00000000 时发生访问冲突
遇见这种问题一般都是空指针,即:指针里没有赋值~ 如果你对null 进行操作就会产生空指针异常 Object obj = new Object(); 你要知道 obj是一个Object指针变量,指向O ...
- xx.exe 中的 0x014180bd 处有未经处理的异常: 0xC0000005: 读取位置 0xfeeefeee 时发生访问冲突(当指针访问异常时,应考虑是不是对象未创建)。
xx.exe 中的 0x014180bd 处有未经处理的异常: 0xC0000005: 读取位置 0xfeeefeee 时发生访问冲突
- vc++,MFC,组合框控件设置时0xC0000005: 读取位置 0x00000020 时发生访问冲突
511.exe 中的 0x78bb5dec (mfc90ud.dll) 处未处理的异常: 0xC0000005: 读取位置 0x00000020 时发生访问冲突 _AFXWIN_INLINE int ...
- 调试器地址出现大小端紊乱,引发的异常: 0xC0000005: 读取位置 0xFFFFFFFFFFFFFFFF 时发生访问冲突。
今天在编写一系列新增需求代码后,开始调试代码 发现上个版本正常可运行的代码出现了:引发的异常: 0xC0000005: 读取位置 0xFFFFFFFFFFFFFFFF 时发生访问冲突. 上个版本数代码 ...
随机推荐
- Holm–Bonferroni method
sklearn实战-乳腺癌细胞数据挖掘(博主亲自录视频) https://study.163.com/course/introduction.htm?courseId=1005269003&u ...
- ELK Betas 6.0安装及使用
Betas 6.0安装及使用 注意: Elastic官网更新非常的快,每个版本的文档有会有不同,具体需要去官网查看最新文档进行配置调整. Beats 平台集合了多种单一用途数据采集器.这些采集器安装后 ...
- linux之nginx的安装
(一)这次是自己折腾服务器的环境,所以自己算是都装过一遍,在装的过程中也是在网上搜索,其实最后在公司运维的指导下知道自己安装出错在哪里的.不说了,直接说安装和问题 (二):首先从 http://ngi ...
- CF760 C. Pavel and barbecue 简单DFS
LINK 题意:给出n个数,\(a_i\)代表下一步会移动到第\(a_i\)个位置,并继续进行操作,\(b_i\)1代表进行一次翻面操作,要求不管以哪个位置上开始,最后都能满足 1.到达过所有位置 2 ...
- cmd下常用命令汇总
1.获得文件夹内所有文件的文件名列表 dir *.png /b>list.txt 其中: (1)*.png表示筛选后缀为.png的文件 (2)/b为输出的模式.如下: 引用 /b 只有文件名 ...
- 超越icon font
很久以前,我们如何使用图标? 1.切图 2.拼合(Sprites) 原始社会啊! 后来CSSGagagrunt-css-sprite 字体图标 相见不曾相识 Emoji绘文字 iconfont.cn直 ...
- [php]禁用缓存
header("Expires: -1"); header("Cache-Control: no_cache"); header("pragma: n ...
- 【BZOJ】1707: [Usaco2007 Nov]tanning分配防晒霜
[算法]贪心扫描线(+堆) [题意]给定n头牛有区间[a,b],m个防晒霜值为ai,每个可以使用bi次,每次可以使包含它的区间涂到防晒霜,问最多被涂牛数. [题解] 参考:[bzoj1707]: [U ...
- 【CodeForces】866D. Buy Low Sell High
[题意]已知n天股价,每天可以买入一股或卖出一股或不作为,最后必须持0股,求最大收益. [算法]堆 贪心? [题解] 不作为思想:[不作为=买入再卖出] 根据不作为思想,可以推出中转站思想. 中转站思 ...
- session_write_close()的作用
简单地说,当开启session_start以后,这个session会一直开启,并且被一个用户使用.其他用户开启session的话要等待第一个session用户关闭以后才可以开启sessio,这样就造成 ...