• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            Sivan's blog

            用代碼說話……
            posts - 14, comments - 2, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            [原]自動注冊程序目錄下的DLL和OCX

            Posted on 2010-12-09 09:15 Sivan 閱讀(2186) 評論(0)  編輯 收藏 引用 所屬分類: VC/MFC
            1.概述  
                經常會遇到這樣的情況:每次重裝了系統,因為注冊表丟失,一些軟件(在非系統分區的軟件目錄)需要重新注冊目錄中的DLL(DLL是組件的需要注冊)或OCX才能成功運行。通常我們會手動在“運行”中輸入“regsvr32 /s dll/ocx路徑”進行手段注冊,或者寫一個如下面形式的批處理文件

            regsvr32 /s Plugin\CBDict08\CBDataSet.dll
            regsvr32 
            /s Plugin\CBNetDict08\CBNetDataSet.dll
            regsvr32 
            /s plugin\CBGoogleDataSet\CBGoogleDataSet.dll
            regsvr32 
            /s plugin\CBNetDicDict\CBNetDicDataSet.dll
            regsvr32 
            /s cache.dll

            批處理文件固然簡單高效,但是將每個目錄中的DLL和OCX都提取出來,然后寫批處理文件也是挺繁瑣的一件事情,能不能只用一個小程序將目錄中的DLL與OCX都自動注冊呢?本文解決這個小問題。

            2.解決方法
            自動注冊程序目錄下的DLL和OCX,需要經過以下幾個步驟。
            獲得本程序所在目錄路徑→搜尋本目錄下的DLL和OCX文件→裝載DLL或OCX→調用DLL注冊進入點函數DllRegisterServer/或反注冊函數DllUnregisterServer→卸載DLL或OCX。這個過程主要用到了四個函數。
            (1)LoadLibary
            HMODULE LoadLibrary(LPCTSTR lpFileName);
            LoadLibrary載入指定可執行模塊,并將它映射到當前進程地址空間。載入后,可以訪問庫內的資源。
            (2)FreeLibrary
            BOOL FreeLibrary(HMODULE hModule);
            FreeLibrary用于釋放LoadLibary函數載入的動態鏈接庫。
            (3)DllRegisterServer
            STDAPI DllRegisterServer(void);
            通知一個進程內服務創建它的注冊入口點。
            (4)DllUnregisterServer
            STDAPI DllUnregisterServer(void);
            通知進程內服務移除通過DllRegisterServer創建的入口點。
            注意:直接調用DLL內函數需要使用GetProcAddress,而GetProcAddress是Windows API,在Windows32平臺導出函數名是ANSI字符的,它的第二個參數為LPCSTR(const char*)類型,在Unicode編譯模式下,如果第二個參數有L或_T修飾,可能編譯不通。可以寫成如下形式
            (RegSvrFun)GetProcAddress(hModule, (LPCSTR)("DllUnregisterServer"))



            代碼如下:
              1CString CRegisterDlg::GetExePath()
              2{
              3    TCHAR szPath[MAX_PATH];
              4    ::GetModuleFileName(NULL, szPath, MAX_PATH);
              5    TCHAR* pChr = _tcsrchr(szPath, _T('\\'));
              6    CString strVal;
              7    if (pChr != NULL)
              8    {
              9        *pChr = _T('\0');
             10        lstrcpy(strVal.GetBuffer(MAX_PATH), szPath);
             11        strVal.ReleaseBuffer(MAX_PATH);
             12    }
             
             13    return strVal;
             14}

             15
             16void CRegisterDlg::OnBnClickedBtnReg()
             17{
             18    // TODO: 在此添加控件通知處理程序代碼
             19    CString strDir;
             20    strDir = GetExePath();
             21    if (strDir.IsEmpty())
             22    {
             23        MessageBox(_T("尋找程序運行目錄錯誤!"), _T("錯誤"), MB_OK | MB_ICONSTOP);
             24        return;
             25    }

             26
             27    BeginWaitCursor();
             28
             29    CStringArray saAllFile,saFile;
             30    CFileFind filefind;
             31    CString strFind;
             32    BOOL bFind = FALSE;
             33
             34    saAllFile.RemoveAll();
             35    strFind.Format(_T("%s\\*.*"), strDir);
             36    bFind = filefind.FindFile(strFind);
             37    while (bFind)
             38    {
             39        bFind = filefind.FindNextFile();
             40        if (!filefind.IsDirectory() && !filefind.IsDots())
             41        {
             42            CString strPath;
             43            strPath = filefind.GetFilePath();
             44            TRACE(_T("%s\n"),strPath);
             45            saAllFile.Add(strPath.MakeLower());
             46        }

             47    }

             48    saAllFile.FreeExtra();
             49    saFile.RemoveAll();
             50    for (int i=0; i!=saAllFile.GetCount(); ++i)
             51    {
             52        CString strTemp = saAllFile.GetAt(i).Right(4);
             53        if (strTemp == _T(".dll"|| strTemp == _T(".ocx"))
             54        {
             55            saFile.Add(saAllFile.GetAt(i));
             56        }

             57    }

             58    saFile.FreeExtra();
             59    if (saFile.GetCount() == 0)
             60    {
             61        MessageBox(_T("目錄中沒有需要注冊的文件!"), _T("提示"), MB_OK | MB_ICONINFORMATION);
             62        return;
             63    }

             64    CStringArray saOK,saFail;
             65    saOK.RemoveAll();
             66    saFail.RemoveAll();
             67    for (int i=0; i!=saFile.GetCount(); ++i)
             68    {
             69        CString strPath;
             70        strPath = saFile.GetAt(i);
             71        HMODULE hModule = LoadLibrary(strPath);
             72        if (hModule == NULL)
             73        {
             74            saFail.Add(strPath);
             75            return;
             76        }

             77        RegSvrFun DllRegisterServer = (RegSvrFun)GetProcAddress(hModule, (LPCSTR)("DllRegisterServer")); 
             78        if (DllRegisterServer != NULL)
             79        {
             80            HRESULT ret = DllRegisterServer();
             81            if (ret == S_OK)
             82            {
             83                saOK.Add(strPath);
             84            }

             85            else
             86            {
             87                saFail.Add(strPath);
             88            }

             89        }

             90        else
             91        {
             92            saFail.Add(strPath);
             93        }

             94        FreeLibrary(hModule);
             95    }

             96    CString strMsg = _T("注冊成功的文件有:\n");
             97    for (int i=0; i!=saOK.GetCount(); ++i)
             98    {
             99        CString strTemp = saOK.GetAt(i);
            100        strTemp += _T("\n");
            101        strMsg += strTemp;
            102    }

            103    strMsg += _T("\n注冊失敗的文件有:\n");
            104    for (int i=0; i!=saFail.GetCount(); ++i)
            105    {
            106        CString strTemp = saFail.GetAt(i);
            107        strTemp += _T("\n");
            108        strMsg += strTemp;
            109    }

            110    EndWaitCursor();
            111    MessageBox(strMsg,_T("提示"),MB_OK | MB_ICONINFORMATION);
            112}

            色综合合久久天天给综看| 欧美牲交A欧牲交aⅴ久久| 久久精品人成免费| 国内精品伊人久久久久影院对白| 婷婷久久综合| 日产精品久久久一区二区| 久久国产精品99久久久久久老狼 | 国产精品久久久久久久午夜片| 久久久久免费精品国产| 777久久精品一区二区三区无码| 久久伊人影视| 久久国产三级无码一区二区| 久久精品国产一区| 2019久久久高清456| 香蕉久久夜色精品国产尤物| 欧美精品福利视频一区二区三区久久久精品 | 狠狠色丁香婷婷综合久久来| 亚洲精品97久久中文字幕无码| 久久久久久久久无码精品亚洲日韩| 精品久久久久久成人AV| 99久久做夜夜爱天天做精品| 久久久久亚洲av成人网人人软件 | 狠狠色丁香婷婷久久综合五月 | 国产精品嫩草影院久久| 欧美亚洲国产精品久久| 久久国产香蕉一区精品| 久久人人爽人人爽人人片AV不 | 国产精品gz久久久| 久久99久久99小草精品免视看| 久久久久99这里有精品10| 久久综合伊人77777| 国产精品综合久久第一页| 精品久久久久久中文字幕| 1000部精品久久久久久久久| 色婷婷久久久SWAG精品| 色偷偷888欧美精品久久久| 色成年激情久久综合| 99久久精品日本一区二区免费| 99蜜桃臀久久久欧美精品网站| 久久国产色AV免费观看| 久久免费的精品国产V∧|