初学C++ 远程线程注入DLL与卸载

这篇博客介绍了如何在C++中实现远程线程注入DLL到指定进程(如notepad.exe),以及如何卸载已注入的DLL。通过DebugPrivilege函数提升权限,使用OpenProcess、VirtualAllocEx、WriteProcessMemory、CreateRemoteThread等API完成注入,再利用类似方法配合FreeLibrary卸载DLL。
摘要由CSDN通过智能技术生成
//提升权限
void DebugPrivilege()
{
 HANDLE hToken = NULL;
 //打开当前进程的访问令牌
 int hRet = OpenProcessToken(GetCurrentProcess(),TOKEN_ALL_ACCESS,&hToken);
 if( hRet)
 {
  TOKEN_PRIVILEGES tp;
  tp.PrivilegeCount = 1;
  //取得描述权限的LUID
  LookupPrivilegeValue(NULL,SE_DEBUG_NAME,&tp.Privileges[0].Luid);
  tp.Privileges[0].Attributes = SE_PRIVILEGE_ENABLED;
  //调整访问令牌的权限
  AdjustTokenPrivileges(hToken,FALSE,&tp,sizeof(tp),NULL,NULL);
  CloseHandle(hToken);
 }
}
void InpouringDll()//注入
{
WCHAR *DllName = _T("C:\\Users\\yjip\\Documents\\Visual Studio 2008\\Projects\\tetst\\Debug\\TestDLL.dll");
DWORD ProcessID = GetProcessIdByName(L"notepad.exe");//得到进程ID//explorer
DebugPrivilege();
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值