接上回,现在的Active是真正意义上的Active了,然后我们在Demo中加入ShowMessage方法:
public void ShowMessage(string msg)
{
if(msg!=null)
{
MessageBox.Show(msg);
}
}
如下图示:
再重新编译.然后我们修改test.html的代码如下,新增一按钮用于调用刚加的ShowMessage时事,现在再在IE里打开网址,我们就可以做交互了.但结果却让人失望,我们发现IE跳出了拦截对话框,说Active控件不安全,不能与JS进行交互,如下图示:
根据提示,我们判断可以通过修改IE的设置使控件运行。打开IE的 工具->Internet选项->安全->本地Intranet->自定义级别->对没有标记为安全的ActiveX控件进行初始化和运行,将其值设为启用。我们刷新页面,现在终于可以正确运行了,点击按钮会弹出"hello world"的对话框.
当然,我们不能指望我们的客户和我们一样修改这个值。毕竟,一是操作麻烦,二是给电脑带来了很大的安全风险。在互联网上搜索之后,发现必须要实现IObjectSafety接口,把ActiveX控件标记为安全的ActiveX控件。在搜索MSDN之后,我找到了IObjectSafety接口的定义。这就好办了。首先我们自己用C#实现这个接口:
实现IObjectSafety的方法如下:
先在命名空间里定义好该接口及实现方法,代码如下:
[Guid("CB5BDC81-93C1-11CF-8F20-00805F2CD064"), InterfaceType(ComInterfaceType.InterfaceIsIUnknown)]
public interface IObjectSafety
{
void GetInterfacceSafyOptions(System.Int32 riid,out System.Int32 pdwSupportedOptions,out System.Int32 pdwEnabledOptions);
void SetInterfaceSafetyOptions(System.Int32 riid,System.Int32 dwOptionsSetMask,System.Int32 dwEnabledOptions);
}
图示:
然后,将我们的Demo继承此接口,用如下语句:public class UserControl1 : System.Windows.Forms.UserControl,IObjectSafety,图示如上.
然后我们在类UserControl1中实现IObjectSafety的方法,代码如下(不需要修改):
public void GetInterfacceSafyOptions(System.Int32 riid,out System.Int32 pdwSupportedOptions,out System.Int32 pdwEnabledOptions)
{
pdwSupportedOptions = 1; //不要修改该代码
pdwEnabledOptions = 2; //不要修改该代码
//return;
}
public void SetInterfaceSafetyOptions(System.Int32 riid,System.Int32 dwOptionsSetMask,System.Int32 dwEnabledOptions)
{
//return;
}
如下图示:
重新编译,然后我们再次在IE里运行测试页面test.html,些时我们发现一切功能都正常了.图示如下:
至此,我们的Active基本成功,可以在此基础上根据自已的需要再加相关的功能.
来源:http://hi.baidu.com/meteortent/blog/item/e934e1ae1f50c2dd7cd92ac6.html