zoukankan      html  css  js  c++  java
  • mfc HackerTools释放资源

    作用:

    在VC环境中除了我们所常用的Dialog、Menu和Bitmap等标准资源类型之外,它还支持自定义资源类型(Custom Resource),我们自定义的资源类型能做些什么呢?呵呵,用处多多。

    1.      默认的皮肤压缩包或语言包。一些支持换肤的软件特别是一些媒体播放器常常有自定义的皮肤文件(你可以尝试将Media Player或千千静听等软件的Skins目录下的文件的扩展名改为.zip,然后使用WinZip打开看一下),但为了防止Skin文件丢失导致软件无 法显示,他们常常会在EXE文件中内置一套Skin作为默认的皮肤文件。同样,一些支持多语言的EXE文件中存在默认语言包也是这个道理(当然也可以使用 "String Table"资源类型);

    2.      做为一些病毒/木马程序的寄生方式。如果不小心执行了带有病毒/木马的程序,它们会在你运行时释放出病毒/木马文件。当然许多病毒是将自身写入PE文件头来实现;

    3.      合并EXE与它所需要的DLL文件。出于某些原因程序作者有时可能需要将DLL文件嵌入到可执行的EXE文件中,这可以通过使用自定义资源来实现;

    4.      其它需要在程序中播放一个AVI动画等等,都可以通过将二进制的数据文件作为自定义资源加入到可执行文件中来实现;

    来自:https://www.cnblogs.com/gakusei/articles/1352922.html

    //获取指定模块的资源
        HRSRC hRsrc1 = FindResource(NULL, MAKEINTRESOURCE(IDR_GUISHOU1), TEXT("GUISHOU"));
        HRSRC hRsrc2 = FindResource(NULL, MAKEINTRESOURCE(IDR_GUISHOU2), TEXT("GUISHOU"));
    
        if (hRsrc1==NULL|| hRsrc2==NULL)
        {
            m_Edit += L"查找资源失败
    ";
        }
        else
        {
            m_Edit += L"查找资源成功
    ";
        }
        
        //获取资源大小
        DWORD dwSize1 = SizeofResource(NULL, hRsrc1);
        DWORD dwSize2 = SizeofResource(NULL, hRsrc2);
        if (dwSize1&&dwSize2)
        {
            m_Edit += L"获取资源大小成功
    ";
        }
        else
        {
            m_Edit += L"获取资源大小失败
    ";
        }
    
        //将资源加载到内存
        HGLOBAL hGlobal1 = LoadResource(NULL, hRsrc1);
        HGLOBAL hGlobal2 = LoadResource(NULL, hRsrc2);
        if (hGlobal1&&hGlobal1)
        {
            m_Edit += L"资源加载成功
    ";
        }
        else
        {
            m_Edit += L"资源加载失败
    ";
        }
    
        //锁定资源
        LPVOID lpVoid1 = LockResource(hGlobal1);
        LPVOID lpVoid2 = LockResource(hGlobal2);
        if (lpVoid1&&lpVoid2)
        {
            m_Edit += L"资源锁定成功
    ";
        }
        else
        {
            m_Edit += L"资源锁定失败
    ";
        }
    
        //将资源保存为文件
        FILE* fp1 = NULL;
        FILE* fp2 = NULL;
        fopen_s(&fp1, "MyHookDll.dll", "wb+");
        fopen_s(&fp2, "TestDll.dll", "wb+");
        if (fp1&&fp2)
        {
            m_Edit += L"资源载入本地成功
    ";
        }
        fwrite(lpVoid1,sizeof(char),dwSize1,fp1);
        fwrite(lpVoid2,sizeof(char),dwSize2,fp2);
        fclose(fp1);
        fclose(fp2);
        UpdateData(FALSE);

       FindResource用来在一个指定的模块中定位所指定的资源:

                 HRSRC FindResource(

                 HMODULE hModule,                //包含所需资源的模块句柄,如果是程序本身,可以置为NULL

                 LPCTSTR lpName,         //可以是资源名称或资源ID

                 LPCTSTR lpType          //资源类型,在这里也就是我们自己指定的资源类型

                );  

     LoadResource用来将所指定的资源加载到内存当中;

                 HGLOBAL LoadResource(

                 HMODULE hModule,                //模块句柄,同上

              HRSRC hResInfo          //需要加载的资源句柄,这里也就是FindResource的返回值

             );  

    LockResource用来锁定内存中的资源数据块,它的返回值也就是我们要使用的直系指向资源数据的内存指针;

              LPVOID LockResource(

              HGLOBAL hResData                //指向内存中要锁定的资源数据块,这里也就是LoadResource的返回值

              );      

    项目来自:https://github.com/TonyChen56/HackerTools

  • 相关阅读:
    PATA 1071 Speech Patterns.
    PATA 1027 Colors In Mars
    PATB 1038. 统计同成绩学生(20)
    1036. 跟奥巴马一起编程(15)
    PATA 1036. Boys vs Girls (25)
    PATA 1006. Sign In and Sign Out (25)
    读取web工程目录之外的图片并显示
    DOS命令
    java连接oracle集群
    servlet
  • 原文地址:https://www.cnblogs.com/zebra-bin/p/13186648.html
Copyright © 2011-2022 走看看