要使用C#實現一個ActiveX控件,需要解決三個問題:
1.使.Net組件能夠被COM調用
2.在客戶機上注冊後,ActiveX控件能通過IE的安全認證
3.未在客戶機上注冊時,安裝包能通過IE的簽名認證
本程序的開發環境是.NET Framework 3.5,工具是Visual Studio .NET 2008,在安裝.Net Framework 3.5的客戶機上通過測試。
下面是實現步驟:
(一)創建可從COM訪問的程序集
首先實現一個對COM可見的程序集,創建類庫工程,AssemblyInfo.cs應包含:
using System.Runtime.InteropServices;
//使此程序集中的類型對COM組件可見
[assembly: ComVisible(true)]
// 如果此項目向 COM 公開,則下列 GUID 用於類型庫的 ID
[assembly: Guid("94882155-3B7C-48e3-B357-234D56D8F15E")]
加入以下代 碼到AssemblyInfo.cs確保程序集的可訪問性:
using System.Security;
[assembly: AllowPartiallyTrustedCallers()]
注意上面的Guid,如果程序集內部的類 未標注Guid,COM注冊的Guid是會新生成的,此處的Guid沒有作用。
創建用戶控件(自定義類待測)IdentityKey.cs,加入:
using System;
using System.ComponentModel;
using System.Windows.Forms;
using System.Runtime.InteropServices;
namespace KeyActiveX
{
[Guid("94882155-3B7C-48e3-B357-234D56D8F15E")]
public partial class IdentityKey : UserControl
{
}
}
這裡的Guid和AssemblyInfo.cs一樣,它會在COM注冊中成為CLSID並被Html以clsid調用 。
類庫工程屬性中,選擇生成,勾選COM注冊,在Html文件中加入
<object id="controlbyid" classid="clsid:{94882155-3B7C-48e3-B357 -234D56D8F15E}" ></object>
在IE中啟用不安全控件,查看Html頁面,應能訪問到控件,現在一個在發布時對COM注冊的程序集開發 完成了。
使用OLE/COM Object VIEwer(安裝VC自帶)可以在.Net CategorIEs中查看組件和CLSID。