OCX開發與第三方OCX封裝


首先感謝網絡上朋友們無私的共享,我才得以從一無所知到完美解決OCX開發中的問題,如果你也對OCX一竅不通,而需要在WEB客戶端中操作第三方OCX,恰好第三方OCX又無法完全滿足你的需求,那么這篇文章應該對你有所幫助,來吧。

1.創建一個MFC OCX工程

 

 

 點擊完成就ok了

現在你已經創建了一個OCX框架了,你想在WEB上應用嗎?必須實現OCX安全機制,否則IE不會運行的,now,let go!

2.實現安全機制

 

 在FIleView視圖中,打開NewTestCtl.h文件,在public定義中插入如下代碼 

     // 去掉安全警告 BEGIN  
    DECLARE_INTERFACE_MAP()  
        BEGIN_INTERFACE_PART(ObjectSafety, IObjectSafety)  
        STDMETHOD(GetInterfaceSafetyOptions)(REFIID riid, DWORD __RPC_FAR *pdwSupportedOptions, DWORD __RPC_FAR *pdwEnabledOptions);  
        STDMETHOD(SetInterfaceSafetyOptions)(REFIID riid, DWORD dwOptionSetMask, DWORD dwEnabledOptions);  
    END_INTERFACE_PART(ObjectSafety)  

    //去掉安全警告 END   

然后是TestfingerCtrl.CPP文件中IMPLEMENT_DYNCREATE(CTestfingerCtrl, COleControl)代碼后面添加如下代碼

// 去掉安全警告 BEGIN  
BEGIN_INTERFACE_MAP(CTestfingerCtrl, COleControl)  
    INTERFACE_PART(CTestfingerCtrl, IID_IObjectSafety, ObjectSafety)  
END_INTERFACE_MAP()  
  
//  Implementation of IObjectSafety  
STDMETHODIMP CTestfingerCtrl::XObjectSafety::GetInterfaceSafetyOptions(  
    REFIID riid,  
    DWORD __RPC_FAR *pdwSupportedOptions,  
    DWORD __RPC_FAR *pdwEnabledOptions)  
{  
    METHOD_PROLOGUE_EX(CTestfingerCtrl, ObjectSafety);  
     if (!pdwSupportedOptions || !pdwEnabledOptions)  
    {  
         return E_POINTER;  
    }  
    *pdwSupportedOptions = INTERFACESAFE_FOR_UNTRUSTED_CALLER | INTERFACESAFE_FOR_UNTRUSTED_DATA;  
    *pdwEnabledOptions =  0;  
     if (NULL == pThis->GetInterface(&riid))  
    {  
        TRACE( " Requested interface is not supported.\n ");  
         return E_NOINTERFACE;  
    }  
     //  What interface is being checked out anyhow?  
    OLECHAR szGUID[ 39];  
     int i = StringFromGUID2(riid, szGUID,  39);  
     if (riid == IID_IDispatch)  
    {  
         //  Client wants to know if object is safe for scripting  
        *pdwEnabledOptions = INTERFACESAFE_FOR_UNTRUSTED_CALLER;  
         return S_OK;  
    }  
     else  if (riid == IID_IPersistPropertyBag  
            || riid == IID_IPersistStreamInit  
            || riid == IID_IPersistStorage  
            || riid == IID_IPersistMemory)  
    {  
         //  Those are the persistence interfaces COleControl derived controls support  
        
//  as indicated in AFXCTL.H  
        
//  Client wants to know if object is safe for initializing from persistent data  
        *pdwEnabledOptions = INTERFACESAFE_FOR_UNTRUSTED_DATA;  
         return S_OK;  
    }  
     else  
    {  
         //  Find out what interface this is, and decide what options to enable  
        TRACE( " We didn't account for the safety of this interface, and it's one we support\n ");  
         return E_NOINTERFACE;  
    }  
}  
  
STDMETHODIMP CTestfingerCtrl::XObjectSafety::SetInterfaceSafetyOptions(  
    REFIID riid,  
    DWORD dwOptionSetMask,  
    DWORD dwEnabledOptions)  
{  
    METHOD_PROLOGUE_EX(CTestfingerCtrl, ObjectSafety);  
    OLECHAR szGUID[ 39];  
     //  What is this interface anyway?  
    
//  We can do a quick lookup in the registry under HKEY_CLASSES_ROOT\Interface  
     int i = StringFromGUID2(riid, szGUID,  39);  
     if ( 0 == dwOptionSetMask &&  0 == dwEnabledOptions)  
    {  
         //  the control certainly supports NO requests through the specified interface  
        
//  so it"s safe to return S_OK even if the interface isn"t supported.  
         return S_OK;  
    }  
  
     //  Do we support the specified interface?  
     if (NULL == pThis->GetInterface(&riid))  
    {  
        TRACE1( " %s is not support.\n ", szGUID);  
         return E_FAIL;  
    }  
  
     if (riid == IID_IDispatch)  
    {  
        TRACE( " Client asking if it's safe to call through IDispatch.\n ");  
            TRACE( " In other words, is the control safe for scripting?\n ");  
         if (INTERFACESAFE_FOR_UNTRUSTED_CALLER == dwOptionSetMask && INTERFACESAFE_FOR_UNTRUSTED_CALLER == dwEnabledOptions)  
        {  
             return S_OK;  
        }  
         else  
        {  
             return E_FAIL;  
        }  
    }  
     else  if (riid == IID_IPersistPropertyBag  
        || riid == IID_IPersistStreamInit  
        || riid == IID_IPersistStorage  
        || riid == IID_IPersistMemory)  
    {  
        TRACE( " Client asking if it's safe to call through IPersist*.\n ");  
            TRACE( " In other words, is the control safe for initializing from persistent data?\n ");  
         if (INTERFACESAFE_FOR_UNTRUSTED_DATA == dwOptionSetMask && INTERFACESAFE_FOR_UNTRUSTED_DATA == dwEnabledOptions)  
        {  
             return NOERROR;  
        }  
         else  
        {  
             return E_FAIL;  
        }  
    }  
     else  
    {  
        TRACE1( " We didn\"t account for the safety of %s, and it\"s one we support\n ", szGUID);  
         return E_FAIL;  
    }  
}  
  
STDMETHODIMP_(ULONG) CTestfingerCtrl::XObjectSafety::AddRef()  
{  
    METHOD_PROLOGUE_EX_(CTestfingerCtrl, ObjectSafety)  
     return (ULONG)pThis->ExternalAddRef();  
}  
  
STDMETHODIMP_(ULONG) CTestfingerCtrl::XObjectSafety::Release()  
{  
    METHOD_PROLOGUE_EX_(CTestfingerCtrl, ObjectSafety)  
     return (ULONG)pThis->ExternalRelease();  
}  
  
STDMETHODIMP CTestfingerCtrl::XObjectSafety::QueryInterface(REFIID iid, LPVOID* ppvObj)  
{  
    METHOD_PROLOGUE_EX_(CTestfingerCtrl, ObjectSafety)  
     return (HRESULT)pThis->ExternalQueryInterface(&iid, ppvObj);  
}  

//去掉安全警告 END   

 

 好了,編譯吧,這次IE中可以使用了,IE需要classid,打開VC6光盤的COMMON\TOOLS目錄,運行OLEVIEW.EXE文件,查看controls下面newtest控件名字就得到classid了,下圖是百度音樂的classid:3C294567-XXXXXXX

 

好了,基本的OCX框架有了,安全接口有了,下次該把第三方OCX集成進來了,做這個文章太累了,上傳圖片好麻煩,就不能簡單點么?休息一下。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM