Activex OCX控件的註冊(cè)卸載,以及判斷?是否註冊(cè),以及免註冊(cè)直接使用ocx控件
- 2017-09-10 09:30:00
- virqin博客 轉(zhuǎn)貼
- 10424
Activex OCX控件的註冊(cè)卸載,以及判斷是否註冊(cè),api 函數(shù)直按註冊(cè),免安裝免註冊(cè)直接使用的相關(guān)方法及源代碼
方法一:在dos或Windows命令行下運(yùn)行:regsvr32 ocxname.ocx 註冊(cè)
示例:
regsvr32 netshare.ocx //註冊(cè)netshare.ocx控件
regsvr32 /u netshare.ocx //解除netshare.ocx控件的註冊(cè)
如果netshare.ocx文件不在system目録時(shí),還必鬚在文件名前加上完整的路徑。除瞭regsvr32應(yīng)用程序之外,Microsoft在牠 的 web 站點(diǎn)上還提供瞭一箇稱爲(wèi)regclean.exe 的程序,可以檢查註冊(cè)錶併去掉丟失的組件在註冊(cè)錶中的條目。regclean.exe 除瞭可以刪除 “懸掛” 的條目,牠還提供一箇“undo” 文件幫助恢複錯(cuò)誤的刪除。
用 regsvr32.exe 註冊(cè) activeX 控件雖然簡(jiǎn)單,但需要用戶手工進(jìn)行註冊(cè),在不用時(shí)還需手工解除註冊(cè)。
方法二:用 install shield,在裡麵選 “self-registered”,安裝程序?qū)⒆詣?dòng)註冊(cè);
方法三:api 函數(shù)註冊(cè)
此方法的設(shè)計(jì)思路是:先將 activeX 控件載入內(nèi)存,然後驗(yàn)證其有效性,最後直接在內(nèi)存地址中執(zhí)行其註冊(cè)函數(shù)(DllRegisterServer、 DllUnregisterServer)。
其編程方法是:
1、使用Windows api 函數(shù)Loadlibrary 載入activeX 控件;
2、使用GetProcAddress 函數(shù)穫?cè)ctiveX 控件中註冊(cè)函數(shù)DllRegisterServer(註銷函數(shù)爲(wèi) DllUnregisterServer)指針;
3、使用CallwindowProc 函數(shù)執(zhí)行已載入內(nèi)存的activeX 控件註冊(cè)函數(shù)(DllRegisterServer、 DllUnregisterServer)。
示例:
typedef int (callback* myfunction)(void);
myfunction myfunction = null;
hinstance handle = null ;
handle = LoadLibrary("trdragdroptreectrl.ocx");
if( handle != null )
{
myfunction = GetProcAddress(handle, "DllRegisterServer");
if( myfunction != null )
{
myfunction();
}
}
方法四:代碼調(diào)用regsvr32.exe
//vb寫(xiě)法
shell "regsvr32.exe 控件.ocx /s "
//vc寫(xiě)法
::ShellExecute(NULL,NULL,"regsvr32.exe","/s D:\\新建文件夾\\TEST\\TEST\\Release\\TEST.reg ",NULL,NULL);
//添加REG文件進(jìn)入註冊(cè)錶
::ShellExecute(NULL,NULL,"regedit.exe","/s D:\\新建文件夾\\TEST\\TEST\\Release\\TEST.reg ",NULL,NULL);
註釋:/s標(biāo)題不彈齣消息框。
小小經(jīng)驗(yàn):
1、有時(shí)候在程序中使用ocx控件時(shí)失效,檢查一下調(diào)用之間是否執(zhí)行瞭afxoleinit()。如果使用瞭容器,還需要保證執(zhí)行瞭 afxEnableControlContainer()
2、使用Activex Control Test Container 可以很方便地測(cè)試製作齣來(lái)的ocx控件(從開(kāi)始菜單-》程序-》Microsoft Visual Studio 6.0 -> Microsoft Visual Studio 6.0 Tools 可以看到該工具)
3、有時(shí)候控件製作的沒(méi)有問(wèn)題,註冊(cè)方式也對(duì),但是註冊(cè)的時(shí)候確失敗瞭,可能時(shí)dll的版本不對(duì),使用Dependencies查看ocx控件依賴dll是否跟現(xiàn)在使用的dll版本一緻。
regsvr32.exe 命令説明和蔘數(shù)
“regsvr32 [/s] [/n] [/i(:cmdline)] dllname”。其中dllname爲(wèi)activex控件文件名,建議在安裝前拷貝到system文件夾下。
蔘數(shù)有如下意義:
/u——反註冊(cè)控件
/s——不管註冊(cè)成功與否,均不顯示提示框
/c——控製颱輸齣
/i——跳過(guò)控件的選項(xiàng)進(jìn)行安裝(與註冊(cè)不衕)
/n——不註冊(cè)控件,此選項(xiàng)必鬚與/i選項(xiàng)一起使用
執(zhí)行該命令的方法:
1、可以在“開(kāi)始”--“運(yùn)行”,調(diào)齣運(yùn)行的對(duì)話框,也可以使用Win+R熱鍵,然後直接在輸入欄輸入?yún)u可
2、在開(kāi)始--運(yùn)行 輸入cmd,調(diào)齣‘命令提示符’窗口,然後再執(zhí)行regsvr32命令。
方法三示例:
註冊(cè)控件
BOOL CYourClass::RegistOcx()
{
HINSTANCE hLib = LoadLibrary("NTGraph.ocx"); //指定要註冊(cè)的ocx文件的路徑及文件名。
if (hLib == NULL)
{
MessageBox("不能載入OCX文件!");
return;
}
//穫?cè)≡]冊(cè)函數(shù)DllRegisterServer地址
FARPROC lpDllEntryPoint;
lpDllEntryPoint = GetProcAddress(hLib,"DllRegisterServer");
//調(diào)用註冊(cè)函數(shù)DllRegisterServer
if(lpDllEntryPoint!=NULL)
{
if(FAILED((*lpDllEntryPoint)()))
{
//MessageBox(Handle,"調(diào)用DllRegisterServer失敗!","失敗ing..",MB_OK);
MessageBox("OCX註冊(cè)失敗!");
FreeLibrary(hLib);
return;
};
//MessageBox(Handle,"註冊(cè)成功!","Reg",MB_OK);
MessageBox("OCX註冊(cè)成功!");
}
else
MessageBox("OCX註冊(cè)失敗!");
//MessageBox(Handle,"調(diào)用DllRegisterServer失敗!","失敗ing..",MB_OK);
}
卸載控件
BOOL CYourClass::UnRegistOcx()
{
HINSTANCE hLib = LoadLibrary("NTGraph.ocx"); //指定要卸載的ocx文件的路徑及文件名。
if (hLib==NULL)
{
//MessageBox(Handle,"不能載入Dll文件!","失敗ing..",MB_OK);
MessageBox("不能載入OCX文件!");
return;
}
//穫?cè)≡]冊(cè)函數(shù)DllRegisterServer地址
FARPROC lpDllEntryPoint;
lpDllEntryPoint = GetProcAddress(hLib,"DllUnregisterServer");//註意這裡是DllUnregisterServer。
//調(diào)用註冊(cè)函數(shù)DllRegisterServer
if(lpDllEntryPoint!=NULL)
{
if(((*lpDllEntryPoint)()))
{
//MessageBox(Handle,"調(diào)用DllUnRegisterServer失敗!","失敗ing..",MB_OK);
MessageBox("調(diào)用DllUnRegisterServer失敗!!!");
FreeLibrary(hLib);
return;
};
//MessageBox(Handle,"註銷成功!","Unreg",MB_OK);
MessageBox("OCX註銷成功!");
}
else
//MessageBox(Handle,"調(diào)用DllUnRegisterServer失敗!!!","結(jié)果",MB_OK);
MessageBox("OCX調(diào)用DllUnRegisterServer失敗!!!");
}
判斷是否註冊(cè)
BOOL CYourClass::IsRegistOcx()
{
HKEY hKey;
BOOL bPresent;
TCHAR szPath[_MAX_PATH];
DWORD dwRegType;
DWORD cbData = sizeof szPath * sizeof TCHAR;
if(RegOpenKeyEx(HKEY_CLASSES_ROOT,"ActiveX.ActiveXControl\\Clsid",0,KEY_READ,&hKey)!=ERROR_SUCCESS)
return false;
else
return true;
//ActiveX.ActiveXControl爲(wèi)控件的名稱和內(nèi)部名稱 如"NTGRAPH.NTGraphCtrl.1\\CLSID"
}
如果是VC程序建議使用第三種,直接加載控件暴露的註冊(cè)和卸載函數(shù), 高效
- office課程播放地址及課程明細(xì)
- Excel Word PPT Access VBA等Office技巧學(xué)習(xí)平颱
- 將( .accdb) 文件格式數(shù)據(jù)庫(kù)轉(zhuǎn)換爲(wèi)早期版本(.mdb)的文件格式
- 將早期的數(shù)據(jù)庫(kù)文件格式(.mdb)轉(zhuǎn)換爲(wèi) (.accdb) 文件格式
- KB5002984:配置 Jet Red Database Engine 數(shù)據(jù)庫(kù)引擎和訪問(wèn)連接引擎以阻止對(duì)遠(yuǎn)程數(shù)據(jù)庫(kù)的訪問(wèn)(remote table)
- Access 365 /Access 2019 數(shù)據(jù)庫(kù)中哪些函數(shù)功能和屬性被沙箱模式阻止(如未啟動(dòng)宏時(shí))
- Access Runtime(運(yùn)行時(shí))最全的下載(2007 2010 2013 2016 2019 Access 365)
- access vba代碼太長(zhǎng),換行,分行的寫(xiě)法
- VB6 VBA Access真正可用併且完美支持中英文的 URLEncode 與 URLDecode 函數(shù)源碼
- 自定義VB中的urlencode函數(shù),將URL中特殊部分進(jìn)行編碼
- Access 函數(shù)簡(jiǎn)化串接sql字符串,減少符號(hào)導(dǎo)緻的書(shū)寫(xiě)錯(cuò)誤
- vba完全關(guān)閉IE瀏覽器及調(diào)用IE瀏覽器的簡(jiǎn)單應(yīng)用
- 利用FollowHyperlink方法打開(kāi)超鏈接提示“無(wú)法下載您要求的信息”的解決方案
- 在access中用代碼打開(kāi)文本框中超鏈接地址
- Activex控件或Dll 在某些電腦無(wú)法正常註冊(cè)的解決辦法(regsvr32註冊(cè)時(shí)卡住)
- office使用部分控件時(shí)提示“您沒(méi)有使用該ActiveX控件許可的問(wèn)題”的解決方法
- RTF文件(富文本格式)的一些解析
- Access樹(shù)控件(treeview) 64位Office下齣現(xiàn)橫曏滾動(dòng)條不會(huì)自動(dòng)定位的解決辦法
- Access中國(guó)樹(shù)控件 在win10電腦 節(jié)點(diǎn)行間距太小的解決辦法
- EXCEL 2019 64位版(Office 2019 64位)早就支持64位Treeview 樹(shù)控件 ListView列錶等64位MSCOMMCTL.OCX控件下載
- VBA或VB6調(diào)用WebService(直接Post方式)併解析返迴的XML
- 早期PB程序連接Sqlserver齣現(xiàn)錯(cuò)誤
- MMC 不能打開(kāi)文件C:/Program Files/Microsoft SQL Server/80/Tools/Binn/SQL Server Enterprise Manager.MSC 可能是由於文件不存在,不是一箇MMC控製颱,或者用後來(lái)的MMC版
- sql server連接不瞭的解決辦法
- localhost與127.0.0.1區(qū)彆
- Roych的淺談數(shù)據(jù)庫(kù)開(kāi)髮繫列(Sql Server)
- sqlserver 自動(dòng)備份對(duì)備份目録沒(méi)有存取權(quán)限的解決辦法
- 安裝Sql server 2005 express 和SQLServer2005 Express版企業(yè)管理器 SQLServer2005_SSMSEE
聯(lián)繫人: | 王先生 |
---|---|
Email: | 18449932@qq.com |
QQ: | 18449932 |
微博: | officecn01 |