C#创建Active控件并发布

C#创建Active控件并发布(一) (2007-09-29 11:29:21)
 首先,建立一个WinForm控件项目MaliActive,并拖入一个Label控件,文字设为MailActiveTest
此时编译项目,可以生成MaliActive.dll。将此dll拷贝到IIS的网站目录下,然后建立一个MaliActive.htm的文件,html代码如下:
<body bgcolor='#cccccc'> 
<object id="mailactive" classid=’http://localhost/MaliActive.dll#MaliActive.Demo’ Width="184" Height="96" VIEWASTEXT> </object> 
</body>
在IE地址栏中输入以下地址: http://localhost/ActiveTest/MaliActive.htm,出现“MailActiveTest”的内容
 
但是问题到这里还没有解决。不相信?你可以试试在另外一台机器上测试,注意需要修改对应的html代码和URL地址。你可以看到这个在原来显示控件的地方是一个红色的叉,或者还会弹出一个对话框,表示这个控件没有任何权限。出现这个结果是微软的默认设置造成的,作者必须在控件所在的控件的 AssemblyInfo.cs/vb 中执行一个安全声明,声明这个控件必须使用赋予的权限,才可以显示出界面。我们在AssemblyInfo.cs中引用System.Security命名空间,并添加一句:
[assembly: AllowPartiallyTrustedCallers()]
在VS2005中还必须修改
[assembly: ComVisible(false)] 为 [assembly: ComVisible(true)]
现在重新编译,并且替换以前的dll,界面又可以显示出来了
 
需要提醒的是,到现在为止,我们编写的还不是真正的ActiveX控件。这个控件到现在为止,还只是能够实现自身的显示,并且不能实现更多的功能,比如实现与脚本的交互或者操作客户端的注册表或者磁盘。这是由于.Net Framework的安全模型所限制的。如果我们希望这个控件突破.Net Framework安全模型的限制,实现与脚本的交互或者操作客户端的注册表或者磁盘的话,必须要让它成为真正的ActiveX控件。下面,我们把刚才的控件变成真正的ActiveX控件
 
首先使用 工具—〉创建GUID 生成一个GUID,并修改UserControl1.cs文件。首先增加引用System.Runtime.InteropServices命名空间,并在Demo前面加入一条语句:
[Guid("de70b19a-bab6-4526-9784-618b6eafcc49")]
 
注意Guid中的字符串,就是你生成的Guid字符串。它是你所生成的ActiveX控件的唯一标识符,然后修改项目属性->生成里的"为 COM Interop 注册"打勾(vs2005中);在VS2003中将"为 COM Interop 注册"设为True;
 
重新编译。VS2003中我们使用工具—〉OLE/COM对象查看器查看,在.NET Category的节点下有一个MaliActive.Demo节点,说明成功;在VS2005中在vs的命令提示符下输入oleview打开OLE/COM对象查看器,然后查看是否成功.
 
现在,我们改写MaliActive.htm,html代码如下:

<body bgcolor=’#CCCCCC'> 
<object id="helloworld" 
   classid="clsid: de70b19a-bab6-4526-9784-618b6eafcc49" Width="184" Height="96"> 
</object> 
</body>

  
 使用IE查看,我们的控件又可以在网页中显示了。不过,这个时候它已经不再是以前的.net WinForm控件了,而是货真价实的ActiveX控件了。 

 

不过,编写ActiveX控件的任务还没有完成。我们还没有实现脚本互动或者读写I/O,也没有实现ActiveX控件的自动分发。在下一篇Blog中,我会完成ActiveX控件的编写

 

C#编写Active控件并发布(二) (2007-09-29 11:54:20)
 在我的上一篇blog中,已经实现了一个最基本的ActiveX控件。当然,我们编写的任务还没有完成。首先,我们先尝试实现和JS的交互能力。  

       我们在Demo中加入ShowMessage方法: 
public void ShowMessage(string msg)  
{  
    if(msg != null)  
    {  
        MessageBox.Show(msg);  
     }  
}
  
 我们重新编译。在重新访问页面之前,我们先来修改html代码: 
<body bgcolor=’#cccccc’> 
<object id="helloworld" 
   classid="clsid: de70b19a-bab6-4526-9784-618b6eafcc49" Width="184" Height="96" 

</object> 
<br> 
<input type=’button’ onclick=’helloworld.ShowMessage(“Hello World!”)’ value=’Click’> 
</body>
现在,重新访问 http://localhost/activeTest/mailActive.htm,单击Click按钮,应该可以实现交互了。
 
但是结果却很遗憾,我们发现IE跳出了提示框.
 
单击确定之后,我们发现JS报错。根据提示,我们判断可以通过修改IE的设置使控件运行。打开IE的工具——〉Internet选项——〉安全——〉本地Intranet——〉自定义级别——〉对没有标记为安全的ActiveX控件进行初始化和运行,将其值设为启用。我们刷新页面,现在终于可以正确运行了
 
当然,我们不能指望我们的客户和我们一样修改这个值。毕竟,一是操作麻烦,二是给电脑带来了很大的安全风险。在互联网上搜索之后,发现必须要实现IObjectSafety接口,把ActiveX控件标记为安全的ActiveX控件。在搜索MSDN之后,我找到了IObjectSafety接口的定义。这就好办了。首先我们自己用C#实现这个接口:
[Guid("CB5BDC81-93C1-11CF-8F20-00805F2CD064"),InterfaceType(ComInterfaceType.InterfaceIsIUnknown)]  
public interface IObjectSafety 
{  
    // methods  
  void GetInterfacceSafyOptions(  
     System.Int32 riid,  
     out System.Int32 pdwSupportedOptions,  
     out System.Int32 pdwEnabledOptions);  
  void SetInterfaceSafetyOptions(  
     System.Int32 riid,  
     System.Int32 dwOptionsSetMask,  
     System.Int32 dwEnabledOptions);         
}
 
注意,这个GUID是不能改的。然后,我们在Demo类里面实现这个接口。增加一下代码:
  #region IObjectSafety 成员  
 
public void GetInterfacceSafyOptions(Int32 riid, out Int32 pdwSupportedOptions, out Int32 pdwEnabledOptions) 

            // TODO:  添加 WebCamControl.GetInterfacceSafyOptions 实现  
       pdwSupportedOptions = 1;  
       pdwEnabledOptions = 2; 
}  
  
public void SetInterfaceSafetyOptions(Int32 riid, Int32 dwOptionsSetMask, Int32 dwEnabledOptions) 
{  
        // TODO:  添加 WebCamControl.SetInterfaceSafetyOptions 实现             
}  
  
#endregion  

  重新编译,然后将IE里面的设置改回来。现在,我们发现,和JS的交互已经没有问题了
 
这样,一个最基本的ActiveX控件已经写好了。你可以在这个控件的基础上增加任何你需要的功能。到这里,编写控件的任务已经完成了,我们的下一个目标就是发布它
C#编写Active控件并发布(三) (2007-09-29 12:01:22)
  在前面我们已经完成了ActiveX控件的开发,接下来的就是发布它了
 
采用cab发布,cab好处在于它采用了压缩,支持新老版本的替换,支持多个文件的发布,可以使用数字签名进行签署.

上网下载下面的几个工具,一般微软提供的PDK完整版都有(VS2005中都有)

makecert.exe   制作测试证书用

Cert2Spc.Exe 顾名思义,把cert 转换成 spc证书

CabArc.Exe     打包成cab文件用

signtool.exe  把证书往cab文件里面签署

先制作测试证书或者上网注册一个免费证书,

我上了www.ca365.com注册了某个免费证书,安装到电脑上,再通过IE把它导出为cert证书文件

cert2spc mail.cer mail.spc   =>生成SPC证书

编写cab信息文件:mail.info

[version]
signature="$CHICAGO$"
AdvancedINF=2.0 

[Add.Code]
MailActive.dll=MailActive.dll


[MailActive.dll]
file-win32-x86=thiscab
clsid={de70b19a-bab6-4526-9784-618b6eafcc49}
FileVersion=1,0,0,2
RegisterServer=yes 

 

然后进行打包

CabArc -s 6144 n d:/mail.cab d:/mail.dll d:/mail.inf

生成mail.cab文件

 

现在对mail.cab文件签名

在VS2005的命令提示符下输入

signtool signwizard

打开数字签名向导,按向导将生成的mail.spc文件或存储区的证书导入mail.cab文件即可

然后修改mailactive.htm文件

<body bgcolor='#cccccc'> 
<object id="mailactive" classid="clsid:DE70B19A-BAB6-4526-9784-618B6EAFCC49" Width="0" Height="0" codebase="MailActive.cab#version=1.0.0.2" ></object> 
<br>
<input type="button"  onclick='mailactive.ShowMessage("ok");' value="Click" >

 </body>

浏览器会提示安装,然后安装后即可浏览成功.

到此,编写active控件完成.

 

然后是客户端注册active控件(Net版):

regasm MailActive.dll /tlb /codebase

 

发布时也可以用CAB包发布:

将Jmail.dll文件和mailSetup.msi文件打包成.cab文件,最后签名发布就可以了.

打包成cab文件见:http://dev.youkuaiyun.com/article/article/44/article/48/48338.shtm

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值