要使用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。