zoukankan      html  css  js  c++  java
  • DLL函数重定向

    #pragma comment(linker,"/export:?fnDLL@@YAHXZ=DLL.?fnDLL@@YAHXZ,@1") 

    #pragma comment(linker,"/export:accept=syswsock32.accept,@1") 

    可实现按函数名称重定向

     把原来的dll改名,把自己的dll改成它的名字,然后用新DLL去调用 

    wsock32.dll的重定向

     // MySocket.cpp : Defines the entry point for the DLL application.

    //

    #include "stdafx.h"

    // wsock32.cpp : Defines the entry point for the DLL application.

    //  Module : 替换系统wsock32.dll,实现封包拦截

    //  Notes: :VC++6.0 XP下编译通过

    //利用函数转发器,将无需拦截的替换wsock32.dll的导出函数转发到syswsock32.dll(原来的替换wsock32.dll),
    //在网上见过替换替换wsock32.dll的文章,但是都没有使用函数转发器,所以都比较复杂

    //:::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::


    #pragma comment(linker,"/export:accept=syswsock32.accept,@1")
    #pragma comment(linker,"/export:bind=syswsock32.bind,@2")
    #pragma comment(linker,"/export:closesocket=syswsock32.closesocket,@3")
    #pragma comment(linker,"/export:connect=syswsock32.connect,@4")
    #pragma comment(linker,"/export:getpeername=syswsock32.getpeername,@5")
    #pragma comment(linker,"/export:getsockname=syswsock32.getsockname,@6")
    #pragma comment(linker,"/export:getsockopt=syswsock32.getsockopt,@7")
    #pragma comment(linker,"/export:htons=syswsock32.htons,@9")
    #pragma comment(linker,"/export:htonl=syswsock32.htonl,@8")
    #pragma comment(linker,"/export:inet_addr=syswsock32.inet_addr,@10")
    #pragma comment(linker,"/export:inet_ntoa=syswsock32.inet_ntoa,@11")
    #pragma comment(linker,"/export:ioctlsocket=syswsock32.ioctlsocket,@12")
    #pragma comment(linker,"/export:listen=syswsock32.listen,@13")
    #pragma comment(linker,"/export:ntohl=syswsock32.ntohl,@14")
    #pragma comment(linker,"/export:ntohs=syswsock32.ntohs,@15")
    #pragma comment(linker,"/export:recv=_recv@16,@16")
    #pragma comment(linker,"/export:recvfrom=_recvfrom@24,@17")
    #pragma comment(linker,"/export:select=syswsock32.select,@18")
    #pragma comment(linker,"/export:send=_send@16,@19")
    #pragma comment(linker,"/export:sendto=_sendto@24,@20")
    #pragma comment(linker,"/export:setsockopt=syswsock32.setsockopt,@21")
    #pragma comment(linker,"/export:socket=syswsock32.socket,@23")
    #pragma comment(linker,"/export:shutdown=syswsock32.shutdown,@22")
    #pragma comment(linker,"/export:MigrateWinsockConfiguration=syswsock32.MigrateWinsockConfiguration,@24")

    #pragma comment(linker,"/export:gethostbyname=syswsock32.gethostbyname,@52")
    #pragma comment(linker,"/export:gethostbyaddr=syswsock32.gethostbyaddr,@51")
    #pragma comment(linker,"/export:getprotobynumber=syswsock32.getprotobynumber,@54")
    #pragma comment(linker,"/export:getprotobyname=syswsock32.getprotobyname,@53")
    #pragma comment(linker,"/export:getservbyport=syswsock32.getservbyport,@56")
    #pragma comment(linker,"/export:getservbyname=syswsock32.getservbyname,@55")
    #pragma comment(linker,"/export:gethostname=syswsock32.gethostname,@57")

    #pragma comment(linker,"/export:WSAAsyncSelect=syswsock32.WSAAsyncSelect,@101")
    #pragma comment(linker,"/export:WSAAsyncGetHostByName=syswsock32.WSAAsyncGetHostByName,@103")
    #pragma comment(linker,"/export:WSAAsyncGetHostByAddr=syswsock32.WSAAsyncGetHostByAddr,@102")
    #pragma comment(linker,"/export:WSAAsyncGetProtoByNumber=syswsock32.WSAAsyncGetProtoByNumber,@104")
    #pragma comment(linker,"/export:WSAAsyncGetProtoByName=syswsock32.WSAAsyncGetProtoByName,@105")
    #pragma comment(linker,"/export:WSAAsyncGetServByPort=syswsock32.WSAAsyncGetServByPort,@106")
    #pragma comment(linker,"/export:WSAAsyncGetServByName=syswsock32.WSAAsyncGetServByName,@107")
    #pragma comment(linker,"/export:WSACancelAsyncRequest=syswsock32.WSACancelAsyncRequest,@108")
    #pragma comment(linker,"/export:WSASetBlockingHook=syswsock32.WSASetBlockingHook,@109")
    #pragma comment(linker,"/export:WSAUnhookBlockingHook=syswsock32.WSAUnhookBlockingHook,@110")
    #pragma comment(linker,"/export:WSAGetLastError=syswsock32.WSAGetLastError,@111")
    #pragma comment(linker,"/export:WSASetLastError=syswsock32.WSASetLastError,@112")
    #pragma comment(linker,"/export:WSACancelBlockingCall=syswsock32.WSACancelBlockingCall,@113")
    #pragma comment(linker,"/export:WSAIsBlocking=syswsock32.WSAIsBlocking,@114")
    #pragma comment(linker,"/export:WSAStartup=syswsock32.WSAStartup,@115")
    #pragma comment(linker,"/export:WSACleanup=syswsock32.WSACleanup,@116")
    #pragma comment(linker,"/export:___WSAFDIsSet=syswsock32.__WSAFDIsSet,@151")


    #pragma comment(linker,"/export:WSARecvEx=syswsock32.WSARecvEx,@1107")
    #pragma comment(linker,"/export:WSApSetPostRoutine=syswsock32.WSApSetPostRoutine,@1000")
    #pragma comment(linker,"/export:WEP=syswsock32.WEP,@500")
    #pragma comment(linker,"/export:TransmitFile=syswsock32.TransmitFile,@1140")
    #pragma comment(linker,"/export:SetServiceW=syswsock32.SetServiceW,@1118")
    #pragma comment(linker,"/export:SetServiceA=syswsock32.SetServiceA,@1117")
    #pragma comment(linker,"/export:sethostname=syswsock32.sethostname,@1105")

    #pragma comment(linker,"/export:s_perror=syswsock32.s_perror,@1108")
    #pragma comment(linker,"/export:rresvport=syswsock32.rresvport,@1104")
    #pragma comment(linker,"/export:rexec=syswsock32.rexec,@1103")
    #pragma comment(linker,"/export:rcmd=syswsock32.rcmd,@1102")
    #pragma comment(linker,"/export:NPLoadNameSpaces=syswsock32.NPLoadNameSpaces,@1130")

    #pragma comment(linker,"/export:inet_network=syswsock32.inet_network,@1100")
    #pragma comment(linker,"/export:GetTypeByNameW=syswsock32.GetTypeByNameW,@1114")
    #pragma comment(linker,"/export:GetTypeByNameA=syswsock32.GetTypeByNameA,@1113")
    #pragma comment(linker,"/export:GetServiceW=syswsock32.GetServiceW,@1120")
    #pragma comment(linker,"/export:GetServiceA=syswsock32.GetServiceA,@1119")
    #pragma comment(linker,"/export:getnetbyname=syswsock32.getnetbyname,@1101")
    #pragma comment(linker,"/export:GetNameByTypeW=syswsock32.GetNameByTypeW,@1116")
    #pragma comment(linker,"/export:GetNameByTypeA=syswsock32.GetNameByTypeA,@1115")
    #pragma comment(linker,"/export:GetAddressByNameW=syswsock32.GetAddressByNameW,@1110")
    #pragma comment(linker,"/export:GetAddressByNameA=syswsock32.GetAddressByNameA,@1109")
    #pragma comment(linker,"/export:GetAcceptExSockaddrs=syswsock32.GetAcceptExSockaddrs,@1142")
    #pragma comment(linker,"/export:EnumProtocolsW=syswsock32.EnumProtocolsW,@1112")
    #pragma comment(linker,"/export:EnumProtocolsA=syswsock32.EnumProtocolsA,@1111")
    #pragma comment(linker,"/export:dn_expand=syswsock32.dn_expand,@1106")
    #pragma comment(linker,"/export:AcceptEx=syswsock32.AcceptEx,@1141")



    typedef int (WINAPI *PFUN)(int s,const char * buf,int len,int flags);
    PFUN mySend,myRecv;

    typedef int (WINAPI *PFUN2)(int s,char *buf,int len,int flags,int to,int tolen);
    PFUN2 mySendto,myRecvfrom;
    void SendData(int cmd,int len,char *pbuffer,int sendORrecv);

    HINSTANCE hws2_32;
    HWND ServerHwnd;

    BOOL APIENTRY DllMain( HANDLE hModule, 
                          DWORD  ul_reason_for_call, 
                          LPVOID lpReserved
                          )
    {
        switch(ul_reason_for_call)
        {
        case DLL_PROCESS_ATTACH:
            hws2_32=LoadLibrary("ws2_32.dll");
            mySend=(PFUN)GetProcAddress(hws2_32,"send");
            myRecv=(PFUN)GetProcAddress(hws2_32,"recv");
            mySendto=(PFUN2)GetProcAddress(hws2_32,"sendto");
            myRecvfrom=(PFUN2)GetProcAddress(hws2_32,"recvfrom");
            ServerHwnd=FindWindow("TForm1","Server");
            break;
        case DLL_PROCESS_DETACH:
            break;
        case DLL_THREAD_ATTACH:
            break;
        case DLL_THREAD_DETACH:
            break;
        }
        return TRUE;
    }

    extern "C" __declspec(dllexport) int WINAPI send(int s,char *buf,int len,int flags)
    {
        
        SendData(s,len,buf,1);
        return mySend(s,buf,len,flags);
    }
    extern "C" __declspec(dllexport) int WINAPI sendto(int s,char *buf,int len,int flags,int to,int tolen)
    {
        SendData(s,len,buf,1);
        return mySendto(s,buf,len,flags,to,tolen);
    }
    extern "C" __declspec(dllexport) int WINAPI recv(int s,char *buf,int len,int flags)
    {
        int rt;
        rt=myRecv(s,buf,len,flags);
        SendData(s,rt,buf,0);
        return rt;
    }
    extern "C" __declspec(dllexport) int WINAPI recvfrom(int s,char *buf,int len,int flags,int from,int fromlen)
    {
        int rt;
        rt=myRecvfrom(s,buf,len,flags,from,fromlen);
        SendData(s,rt,buf,0);
        return rt;
    }
    //------------------------------------------------
    void SendData(int cmd,int len,char *pbuffer,int sendORrecv)
    {
        COPYDATASTRUCT copydata;
        copydata.dwData=cmd;
        copydata.cbData=len;
        copydata.lpData=pbuffer;
        if(::IsWindow(ServerHwnd))
        {
            ::SendMessage(ServerHwnd,WM_COPYDATA,sendORrecv,(LPARAM)&copydata);
        }
    }
  • 相关阅读:
    Windows Server 2008 下解析二级域名的方法
    浅谈2D游戏设计模式--游戏剧情设计(1)
    公司做项目的几点经验总结(个人经验)
    ASP.NET 实现站内信功能(点对点发送,管理员群发)
    FusionChart 水印破解方法(代码版)
    如何使用SOIL在VS2012的 C++环境下显示图片
    C语言实现控制台中光标随意移动
    ASP.NET CMS模板培训教程
    如何用easyui+JAVA 实现动态拼凑datagrid表格(续)
    用JAVA实现插值查询的方法(算近似值,区间求法)
  • 原文地址:https://www.cnblogs.com/ahuo/p/2324544.html
Copyright © 2011-2022 走看看