您的位置:首页 > 其它

PPPOE登录程序二(启动进程部分plck)

2010-08-20 13:59 183 查看
//代码全部在这里,主要是主进程挂起,等待线程正常或者异常退出
// plck.cpp : 定义应用程序的入口点。
//

#include "stdafx.h"
#include "plck.h"
#pragma comment(lib,"shell32.lib")

#define MAX_LOADSTRING 100

// 全局变量:
HINSTANCE hInst; // 当前实例

void protect(HANDLE);

// 此代码模块中包含的函数的前向声明:
int APIENTRY _tWinMain(HINSTANCE hInstance,
HINSTANCE hPrevInstance,
LPTSTR lpCmdLine,
int nCmdShow)
{
UNREFERENCED_PARAMETER(hPrevInstance);
UNREFERENCED_PARAMETER(lpCmdLine);
DWORD exit_code;

// TODO: 在此放置代码。

DWORD id=0;
HANDLE hThread=CreateThread(NULL,0,(LPTHREAD_START_ROUTINE)protect,(LPVOID)::GetCurrentProcess(),0,&id);
// protect(::GetCurrentProcess());
// MessageBox(NULL,_T("test msg!!"),_T("test"),0);
::WaitForSingleObject(hThread,INFINITE);
::GetExitCodeThread(hThread,&exit_code);

CloseHandle(hThread);
return exit_code;
}

void protect(HANDLE p)
{
DWORD exit_code=0;

SHELLEXECUTEINFO ShExecInfo = {0};
ShExecInfo.cbSize = sizeof(SHELLEXECUTEINFO);
ShExecInfo.fMask = SEE_MASK_NOCLOSEPROCESS;
ShExecInfo.hwnd = NULL;
ShExecInfo.lpVerb = NULL;
ShExecInfo.lpFile = _T("C://Program Files//Win//NtuSoftware//locked.exe");
ShExecInfo.lpParameters =NULL;
ShExecInfo.lpDirectory = NULL;
ShExecInfo.nShow = SW_SHOW;
ShExecInfo.hInstApp = NULL;
if(!ShellExecuteEx(&ShExecInfo))
{
MessageBox(NULL,_T("开启线程错误!!"),_T("提示"),MB_OK|MB_ICONERROR);
return ;
}
WaitForSingleObject(ShExecInfo.hProcess,INFINITE);
GetExitCodeProcess(ShExecInfo.hProcess,&exit_code);
if(exit_code==69)
{
::TerminateProcess(p,69);
}
else
{
while(true)
{
/// MessageBox(NULL,_T("线程被异常卸载,电脑将5秒后重启!!"),_T("提示"),MB_OK|MB_ICONERROR);
ShellExecute(NULL,NULL,_T("shutdown"),_T("-s -t 5000 -c locked.exe进程被异常卸载,电脑将5秒后重启!!"),NULL,1);
Sleep(15*1000);
}

}

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐