如何在ASP.NET頁面中嵌入WINFORM控制項

來源:互聯網
上載者:User

 前些日子做一個Web項目,必須自己編寫一個ActiveX控制項。如今的ActiveX控制項大多是使用VB/C++來開發的,而我對他們並不熟悉,因此考慮使用熟悉的C#編寫ActiveX控制項。

    首先,建立一個WinForm控制項項目HelloWorld,並拖入一個Label控制項,文字設為HelloWorld,

UserControl1.cs內容如下:

using System;
using System.Collections;
using System.ComponentModel;
using System.Drawing;
using System.Data;
using System.Windows.Forms;

namespace HelloWorld
{
    /**//// <summary>
    /// UserControl1 的摘要說明。
    /// </summary>
    public class Demo : System.Windows.Forms.UserControl
    {
        private System.Windows.Forms.Label label1;
        /**//// <summary>
        /// 必需的設計器變數。
        /// </summary>
        private System.ComponentModel.Container components = null;

        public Demo()
        {
            // 該調用是 Windows.Forms 表單設計器所必需的。
            InitializeComponent();

            // TODO: 在 InitComponent 調用後添加任何初始化

        }

        /**//// <summary>
        /// 清理所有正在使用的資源。
        /// </summary>
        protected override void Dispose( bool disposing )
        {
            if( disposing )
            {
                if( components != null )
                    components.Dispose();
            }
            base.Dispose( disposing );
        }

        組件設計器產生的程式碼#region 組件設計器產生的程式碼
        /**//// <summary>
        /// 設計器支援所需的方法 - 不要使用代碼編輯器 
        /// 修改此方法的內容。
        /// </summary>
        private void InitializeComponent()
        {
            this.label1 = new System.Windows.Forms.Label();
            this.SuspendLayout();
            // 
            // label1
            // 
            this.label1.Location = new System.Drawing.Point(32, 32);
            this.label1.Name = "label1";
            this.label1.Size = new System.Drawing.Size(120, 32);
            this.label1.TabIndex = 0;
            this.label1.Text = "HelloWorld";
            this.label1.TextAlign = System.Drawing.ContentAlignment.MiddleCenter;
            // 
            // Demo
            // 
            this.Controls.Add(this.label1);
            this.Name = "Demo";
            this.Size = new System.Drawing.Size(184, 96);
            this.ResumeLayout(false);

        }
        #endregion
    }
}

    此時編譯項目,可以產生HelloWorld.dll。將此dll拷貝到IIS的虛擬根目錄下,然後建立一個helloworld.htm的檔案,html代碼如下:

<body bgcolor='#223344'>
<object id="helloworld" classid=’http://localhost/HelloWorld.dll#HelloWorld.Demo’ Width="184" Height="96" VIEWASTEXT> </object>
</body>

在IE地址欄中輸入以下地址:http://localhost/helloworld.htm,出現介面:

,控制項已經成功在頁面上顯示了。OK,我們已經完成了第一步。

    但是問題到這裡還沒有解決。不相信?你可以試試在另外一台機器上測試,注意需要修改對應的html代碼和URL地址。你可以看到這個在原來顯示控制項的地方是一個紅色的叉,或者還會彈出一個對話方塊,表示這個控制項沒有任何許可權。出現這個結果是微軟的預設設定造成的,作者必須在控制項所在的控制項的 AssemblyInfo.cs/vb 中執行一個安全聲明,聲明這個控制項必須使用賦予的許可權,才可以顯示出介面。我們在AssemblyInfo.cs中引用System.Security命名空間,並添加一句:

[assembly : AllowPartiallyTrustedCallers()]

現在重新編譯,並且替換以前的dll,介面又可以顯示出來了。

    需要提醒的是,到現在為止,我們編寫的還不是真正的ActiveX控制項。這個控制項到現在為止,還只是能夠實現自身的顯示,並且不能實現更多的功能,比如實現與指令碼的互動或者操作用戶端的註冊表或者磁碟。這是由於.Net Framework的安全模型所限制的。如果我們希望這個控制項突破.Net Framework安全模型的限制,實現與指令碼的互動或者操作用戶端的註冊表或者磁碟的話,必須要讓它成為真正的ActiveX控制項。下面,我們把剛才的控制項變成真正的ActiveX控制項。

    首先使用 工具—〉建立GUID 產生一個GUID,並修改UserControl1.cs檔案。首先增加引用System.Runtime.InteropServices命名空間,並在Demo前面加入一條語句:

注意Guid中的字串,就是你產生的Guid字串。它是你所產生的ActiveX控制項的唯一識別碼。然後修改項目屬性,

注意面板中的最後一項,我們唯一需要修改的是將其值改為True。

    重新編譯。我們使用 工具—〉OLE/COM對象查看器 查看,

可以看到,我們寫的HelloWorld.Demo已經被正確識別為COM組件。現在,我們已經可以像使用其它ActiveX控制項一樣在網頁中顯示了。在HelloWorld.Demo點擊滑鼠右鍵,

選擇Copy HTML <object> Tag to Clipboard,可以將代碼拷入剪貼簿。

現在,我們改寫helloworld.htm,html代碼如下:

<body bgcolor='#223344'>
<object id="helloworld"
   classid="clsid:9551B223-6188-4387-B293-C7D9D8173E3A" Width="184" Height="96">
</object>
</body>

使用IE查看,我們的控制項又可以在網頁中顯示了。不過,這個時候它已經不再是以前的.net WinForm控制項了,而是貨真價實的ActiveX控制項了。

    不過,編寫ActiveX控制項的任務還沒有完成。我們還沒有實現指令碼互動或者讀寫I/O,也沒有實現ActiveX控制項的自動分發。在下一篇Blog中,我會完成ActiveX控制項的編寫。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.