Activex控件的IObjectSafety接口问题

Posted lihoo

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Activex控件的IObjectSafety接口问题相关的知识,希望对你有一定的参考价值。

http://blog.chinaunix.net/uid-192452-id-3150062.html

 

我的05年做流氓插件的时候,就注意到了这个问题,只要注册表加入
类似的就可以
 HKEY_CLASSES_ROOT\Component
   Categories\{7DD95801-9882-11CF-9FA9-00AA006C42C4}
   HKEY_CLASSES_ROOT\Component
   Categories\{7DD95802-9882-11CF-9FA9-00AA006C42C4}
   HKEY_CLASSES_ROOT\CLSID\{"your controls GUID"}\Implemented
   Categories\{7DD95801-9882-11CF-9FA9-00AA006C42C4}
   HKEY_CLASSES_ROOT\CLSID\{"your controls GUID"}\Implemented
   Categories\{7DD95802-9882-11CF-9FA9-00AA006C42C4}
  
7DD95801-9882-11CF-9FA9-00AA006C42C4为安全空间的ID。
如果是ATL的工程,很简单需要在控件中实现IObjectSafety接口,
class CLoginCtl : 
    .... , 
    public IObjectSafetyImpl<CLoginCtl, INTERFACESAFE_FOR_UNTRUSTED_CALLER | INTERFACESAFE_FOR_UNTRUSTED_DATA> 

... 
BEGIN_COM_MAP(CLoginCtl) 
COM_INTERFACE_ENTRY(IObjectSafety) 
END_COM_MAP() 
... 

或者
BEGIN_CATEGORY_MAP(CLoginCtl) 
IMPLEMENTED_CATEGORY(CATID_SafeForInitializing) 
msdn http://support.microsoft.com/kb/168371/en-us
07年给启明星辰做天清汉马SSLVPN客户端的时候,当时老孟强烈建议使用mfc的ocx,所以就没做atl的,当时使用还是vc6,虽然已经有了vc8。
时隔5年之后,我又开始写SSLVPN客户端,发现vc6写的ocx在IE8上经常崩溃,而且还要处理DEP的问题,只能使用atl8之后的版本。
在初始化控件之前,IE会调用IObjectSafety::SetInterfaceSafetyOptions强制ocx处理不信任的数据初始化和调用。
public IObjectSafetyImpl<CXXXAgent, INTERFACESAFE_FOR_UNTRUSTED_CALLER | INTERFACESAFE_FOR_UNTRUSTED_DATA >,
诡异的是vc8,vc9可以执行public IObjectSafetyImpl<CXXXAgent, INTERFACESAFE_FOR_UNTRUSTED_CALLER | INTERFACESAFE_FOR_UNTRUSTED_DATA | INTERFACE_USES_DISPEX | INTERFACE_USES_SECURITY_MANAGER>,
vc10只能执行public IObjectSafetyImpl<CXXXAgent, INTERFACESAFE_FOR_UNTRUSTED_CALLER | INTERFACESAFE_FOR_UNTRUSTED_DATA >。
 

以上是关于Activex控件的IObjectSafety接口问题的主要内容,如果未能解决你的问题,请参考以下文章

C#创建ActiveX

ActiveX 技术总结

如何找到 ActiveX 控件的接口?

如何使用 MFC 为 ActiveX 控件添加任何可重用接口?

使用 .Net Framework 编写的 Microsoft Access 报表 ActiveX 控件

如何在 MFC No CLR 中访问 Winform ActiveX 控件