C# OCX控件之开发

在C#中,其实没有OCX控件一说,相对应的只是COM组件,编译后也是.DLL,而不是.ocx.所以在C#中,在创建项目时只能创建类库项目。
然后就是具体的代码开发。(略)
要使组件成为能被网页脚本调用的OCX控件,在开发时,要注意以下几点:
1、必须要为将发布OCX控件的主类设置GUID码。该码在创建类库时,C#会自动生成一个(你可以使用,也可以重新生成),并存储在AssemblyInfo.cs中。设置GUID的代码参照以下:
namespace xxxx
{
    [Guid("8d7d8518-ca58-4863-b94d-3c616fda7b35")]//从AssemblyInfo.cs文件中直接复制过来
    public partial class RunData : UserControl, IObjectSafety
    {}
}  
2、必须要实现IObjectSafety接口。该接口需要手工创建一个接口类并让OCX组件实现。
完整的接口代码:(以下接口代码都是固定的,最好不要做其他改动)
using System;
using System.Collections.Generic;
using System.Text;
using System.Web.UI.WebControls.WebParts; //必须引用该包
using System.Security;
using System.Runtime.InteropServices;     //必须引用该包
namespace RunData
{
    /// <summary>
    /// 把控件发布成com组件时必须实现的接口.该接口的GUID是固定的,不能修改,否则组件发布不成功
    /// </summary>
    [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);
    }
}
接口实现:
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;
        }
3、对AssemblyInfo.cs进行编辑,修改相应的属性。包括以下属性及值:
    // 则将该类型上的 ComVisible 属性设置为 true。
    [assembly: ComVisible(true)] //将false更改为true,自动生成的注释也做了说明
    //新添加下面的属性。该属性要求引用System.Security
    [assembly: AllowPartiallyTrustedCallers()]
   // 如果此项目向 COM 公开,则下列 GUID 用于类型库的 ID
   //[assembly: Guid("80c07fca-841c-43c9-bd34-e9f3a6e87a85")]  //注释掉该属性,此属性必须注释,最初我没有注释此属性,生成COM组件老是不成功,有警告,会影响最后的发布.试了N次才试出原因是没有注释此属性。
    要引用:using System.Runtime.InteropServices;
4、编辑工程属性。
   A、在[应用程序]页,输出类型必须指定为“类库”.
   B、在[生成]页,必须勾选“为Com Interop注册”选项。
作了以上修改,如果能编译成功,则表示你的COM组件已够在你本机发布成功了。也说明你的组件本身没什么问题了。

你可以写一个测试网页对你的COM组件进行引用了。
如果是IIS,可以直接使用DLL引用方式进行引用,格式:
<object ></object>
也可以使用clsid方式引用。
如果非IIS应用服务器,如tomcat等,则只能使用CLSID方式。格式:
<OBJECT ID="DataCtl" CLASSID="CLSID:8d7d8518-ca58-4863-b94d-3c616fda7b35"></OBJECT>
"8d7d8518-ca58-4863-b94d-3c616fda7b35"就是最开始提到的那个GUID码!
在本机上运行此网页应该不会出现问题了,因为在开发组件的过程中VS.NET会自动进行组件注册。
使用OLE查看器可以查看当前组件是否成功注册到本机,如果没有找到该组件,应该使用手工注册方式进行注册。
通常情况下手工注册OCX都是采用RegSvr32.exe,但注册C#编写的COM组件推荐使用.NET自带的注册工具RrgAsm.exe工具,而且使用的注册工具版本一定要与开发框架版本一起发布的版本。
 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值