zoukankan      html  css  js  c++  java
  • C#编写ActiveX控件

    用C#编写ActiveX控件

    http://www.cnblogs.com/homer/archive/2005/01/04/86473.html 
    
    http://www.cnblogs.com/homer/archive/2005/01/08/88780.html 
    
    http://www.cnblogs.com/homer/archive/2005/01/26/97822.html 
    http://www.cnblogs.com/xiaoshatian/archive/2008/09/02/1281786.html 
    用C#编写ActiveX控件(一)
    
        前些日子做一个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 ); 
    
            } 
    
     
    
            组件设计器生成的代码 
    
        } 
    
    } 
    
    
        此时编译项目,可以生成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控件的编写。 
    
        PS:这是我在博客园上的第一个Post,希望得到大家的支持。
     
     
    用C#编写ActiveX控件(二)
                                Homer
     
           在我的上一篇blog中,已经实现了一个最基本的ActiveX控件。当然,我们编写的任务还没有完成。首先,我们先尝试实现和JS的交互能力。
     
           我们在Demo中加入ShowMessage方法: 
    
    public void ShowMessage(string msg) 
    
            { 
    
                if(msg != null) 
    
                { 
    
                    MessageBox.Show(msg); 
    
                } 
    
            } 
    
    我们重新编译。在重新访问页面之前,我们先来修改html代码: 
    
    <body bgcolor='#223344'> 
    
    <object id="helloworld" 
    
       classid="clsid:9551B223-6188-4387-B293-C7D9D8173E3A" Width="184" Height="96" 
    
    > 
    
    </object> 
    
    <br> 
    
    <input type='button' onclick='helloworld.ShowMessage(“Hello World!”)' value='Click'> 
    
    </body> 
    
    现在,重新访问http://localhost/helloworld.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类里面实现这个接口。增加一下代码: 
    
    IObjectSafety 成员 
    
    重新编译,然后将IE里面的设置改回来。现在,我们发现,和JS的交互已经没有问题了。 
    
        这样,一个最基本的ActiveX控件已经写好了。你可以在这个控件的基础上增加任何你需要的功能。到这里,编写控件的任务已经完成了,我们的下一个目标就是发布它。
    用C#编写ActiveX控件(三)
    在前面我们已经完成了ActiveX控件的开发,接下来的就是发布它了。 
    
            首先,我们建立一个windows安装项目,并将ActiveX控件的主输出添加到项目输出中。然后,改动ActiveX控件的主输出文件,将其Register属性改为vsdrpCOM.如图: 
    
    下一步,我们改动项目属性,将引导程序更改为 Web引导程序。很遗憾的是,在 Web引导程序设置 中的安装文件夹URL中必须使用绝对路径,不能使用相对路径。这意味着生成安装程序的时候就必须确定路径,不是很方便。在示例中,我使用了localhost,在发布中可以改为实际的域名。
    
        现在我们生成安装程序,并把相应得程序拷贝到正确的目录中(本例中为默认网站目录下的ActiveX文件夹中)。我们可以直接执行Setup.Exe文件,以验证安装文件的正确性。在我的机器上正确执行了,成功了!
     
        现在我们又要重新改动helloworld.htm文件了。修改后的结果如下:
    <body bgcolor='#223344'>
    <object id="helloworld"
       classid="clsid:9551B223-6188-4387-B293-C7D9D8173E3A" Width="184" Height="96" codebase="ActiveX/Setup.Exe"
    > 
    </object>
    <br>
    <input type='button' onclick='helloworld.ShowMessage("Hello World!")' value='Click'>
    </body>
    注意,我们在object块中加入了codebase属性,这就是制定的下载控件的位置,可以使用相对路径。别忙,我们现在还不能正确请求这个页面,因为我们还没有对我们的控件进行签名。签名可以采用两种方式,一种是在上面生成安装程序的时候签名,另一种是使用sn.exe签名。推荐大家使用后者,因为可以提供更多选项。本人很懒,就不多写了,大家可以参考csdn上的文章《发布ActiveX》。先给给大家提个醒,在申请证书的时候选择 高级证书申请。
     
           至此,《用C#编写ActiveX控件》完结。大家有什么问题,可以和我留言。  
    在用c#开发的ActiveX中调用JavaScript方法
    2008-09-02 09:57 by Windie Chai, 7949 visits, 收藏, 编辑
    这段时间要写一个ActiveX控件来控制扫描仪,并在扫描完成之后将文件路径通知页面。因为扫描的过程是异步的,所以我不能利用ActiveX控件公开的Scan方法来返回文件路径,结合Name Ctrl订阅联系人状态的思路,我想,如果可以用JavaScript来订阅ActiveX完成扫描的“事件”,我就可以在这个“事件”中把文件路径当作参数传递给页面了。
    关于如何用c#开发ActiveX控件,红马天下兄的系列文章写的非常不错,我这里主要讲一下如何在ActiveX中调用页面上的JavaScript方法。
    1.引用Microsoft.mshtml
    Microsoft.mshtml的路径是C:Program FilesMicrosoft.NETPrimary Interop AssembliesMicrosoft.mshtml.dll,添加引用后在ActiveX对应类中编写:
    using mshtml;
     
    2.用c#实现两个COM类,IOleClientSite和IOleContainer
    
    [ComImport,
     Guid("00000118-0000-0000-C000-000000000046"),
     InterfaceType(ComInterfaceType.InterfaceIsIUnknown)]
    public interface IOleClientSite
     {
    void SaveObject();
    void GetMoniker(uint dwAssign, uint dwWhichMoniker, object ppmk);
    void GetContainer(out IOleContainer ppContainer);
    void ShowObject();
    void OnShowWindow(bool fShow);
    void RequestNewObjectLayout();
     }
    
    [ComImport,
     Guid("0000011B-0000-0000-C000-000000000046"),
     InterfaceTypeAttribute(ComInterfaceType.InterfaceIsIUnknown)]
    public interface IOleContainer
     {
    void EnumObjects([In, MarshalAs(UnmanagedType.U4)] int grfFlags,
     [Out, MarshalAs(UnmanagedType.LPArray)] object[] ppenum);
    void ParseDisplayName([In, MarshalAs(UnmanagedType.Interface)] object pbc,
     [In, MarshalAs(UnmanagedType.BStr)] string pszDisplayName,
     [Out, MarshalAs(UnmanagedType.LPArray)] int[] pchEaten,
     [Out, MarshalAs(UnmanagedType.LPArray)] object[] ppmkOut);
    void LockContainer([In, MarshalAs(UnmanagedType.I4)] int fLock);
     }
    
    3.调用JavaScript方法
    在Activex控件的对应类中就可以编写如下的CallJavaScript方法:
    
    private void CallJavaScript(string Filenames)
    {
     Type typeIOleObject = this.GetType().GetInterface("IOleObject",true); 
    object oleClientSite = typeIOleObject.InvokeMember("GetClientSite",
     BindingFlags.Instance|BindingFlags.InvokeMethod|BindingFlags.Public,
    null,
    this,
    null); 
    
     IOleClientSite oleClientSite2 = oleClientSite as IOleClientSite;
     IOleContainer pObj;
     oleClientSite2.GetContainer(out pObj);
    
    //参数数组
    object[] args = new object[1];
     args[0] = Filenames;
    
    //获取页面的Script集合
     IHTMLDocument pDoc2 = (IHTMLDocument)pObj;
    object script = pDoc2.Script;
    
    try
     {
    //调用JavaScript方法OnScaned并传递参数,因为此方法可能并没有在页面中实现,所以要进行异常处理
     script.GetType().InvokeMember("OnScaned",
     BindingFlags.Instance | BindingFlags.InvokeMethod | BindingFlags.Public,
    null, 
     script, 
     args);
     }
    catch { }
    }
    
     
    4.在页面中实现相应的JavaScript方法
    在包含这个ActiveX控件的页面中添加如下的JavaScript方法:
    
    <script type="text/javascript"> 
    function OnScaned(files)
     {
    if(files)
     {
    //do something
     }
     } 
    </script>
    
    这样,在ActiveX控件中调用CallJavaScript方法时,最终就会调用到页面中的OnScaned方法,藉此实现了ActiveX的“事件”机制。
    
    在测试的过程中发现一些有趣的事情,不妨也和大家分享一下:
    1. object元素的结束:object元素只能以<object></object>的方式结束,而不能简单的用<object/>来结束,这样结束的后果是object后边的元素都无法在JavaScript方法中获取,可能是浏览器还认为object元素没有结束吧。
    2. 参数的类型:最初我想在c#中给JavaScript方法传递数组类型的参数,但当JavaScript方法执行时,我发现JavaScript将该参数识别为“unknown”,并且无法对其做任何处理,所以最后只好作罢,用传递以“|”分隔的字符串代替。
    3. 小草的这篇文章提供了更简单的调用JavaScript方法,只需要在初始化时传递页面的window属性,但我还没弄清楚如何给JavaScript传递参数。
    原文发布于coding.windstyle.cn,欢迎访问、订阅并和我交流。
     
    View Code

    用C#编写ActiveX控件,开发浏览器控件,注册ActiveX 控件

    用C#编写ActiveX控件,开发浏览器控件,注册ActiveX 控件
    用C#编写ActiveX控件
    
    
    开发浏览器控件这是本控件开发完成后的一个简单应用。我们可以利用它以本地文件夹为单位来批量更新服务器的文件。多线程文件夹上传实现
    最近做一个Web项目,需要自己编写一个ActiveX控件。ActiveX控件大多是使用C++来开发的,而我对他们并不熟悉,因此考虑使用熟悉的C#编写ActiveX控件。 ActiveX 控件注册
    
      首先,建立一个Windows控件库 项目 My_HtmlControl,并拖入一个textBox控件,此时编译项目,可以生成My_HtmlControl.dll。将此dll拷贝到IIS的虚拟根目录下,然后建立一个aa.htm的文件,html代码如下:
    <body> 
    <object classid="http://localhost/My_HtmlControl.dll#My_HtmlControl.UserControl1" Width="184" Height="96">
    </object>
    </body>
    在IE地址栏中输入以下地址:http://localhost/aa.htm,出现界面:可见textBox控件文本框 控件已经成功在页面上显示了。OK,我们已经完成了第一步。
      但是问题到这里还没有解决。不相信?你可以试试在另外一台机器上测试,注意需要修改对应的html代码和URL地址。你可以看到这个在原来显示控件的地方是一个红色的叉,或者还会弹出一个对话框,表示这个控件没有任何权限。出现这个结果是微软的默认设置造成的,作者必须在控件所在的控件的 AssemblyInfo.cs/vb 中执行一个安全声明,声明这个控件必须使用赋予的权限,才可以显示出界面。
    在AssemblyInfo.cs中using System.Security;命名空间,并添加一句:
    [assembly : AllowPartiallyTrustedCallers()]
      注册ActiveX 控件现在重新编译,并且替换以前的dll,界面又可以显示出来了。
      需要提醒的是,到现在为止,我们编写的还不是真正的ActiveX控件。这个控件到现在为止,还只是能够实现自身的显示,并且不能实现更多的功能,比如实现与脚本的交互或者操作客户端的注册表或者磁盘。这是由于.Net Framework的安全模型所限制的。如果我们希望这个控件突破.Net Framework安全模型的限制,实现与脚本的交互或者操作客户端的注册表或者磁盘的话,必须要让它成为真正的ActiveX控件。下面,我们把刚才的控件变成真正的ActiveX控件。
      首先使用 工具—〉创建GUID 生成一个GUID,
    
    并修改UserControl1.cs文件。首先using System.Runtime.InteropServices;命名空间,并在public class UserControl1 : System.Windows.Forms.UserControl前面加入一条语句类标记:[Guid("93210714-D354-4e64-96A7-2DA3BE0E16BC")]
      注意Guid中的字符串,就是你生成的Guid字符串。它是你所生成的ActiveX控件的唯一标识符。然后修改项目属性,打开项目属性面板->配置属性->生成,将最后一项“为Com Interop注册”,我们唯一需要修改的是将其值改为True。
    
     重新编译。我们使用 工具—〉OLE/COM对象查看器 查看,展开.NET Category 找到My_HtmlControl.UserControl1  可以看到,我们写的My_HtmlControl.UserControl1已经被正确识别为COM组件。现在,我们已经可以像使用其它ActiveX控件一样在网页中显示了。在My_HtmlControl.UserControl1点击鼠标右键,选择Copy HTML <object> Tag to Clipboard,可以将代码拷入剪贴板。
      现在,我们改写aa.htm,html代码如下:
    <body>
    <object id="My_HtmlControl" classid="clsid:93210714-D354-4E64-96A7-2DA3BE0E16BC"></object>
    </body>
    
      使用IE查看,我们的控件又可以在网页中显示了。不过,这个时候它已经不再是以前的.net WinForm控件了,而是货真价实的ActiveX控件了。
      不过,编写ActiveX控件的任务还没有完成。我们还没有实现脚本互动或者读写I/O,也没有实现ActiveX控件的自动分发。下面尝试实现和JS的交互:(在UserControl1.cs中添加)
    public void ShowMessage(string msg)
    {
     if(msg != null)
     {
      MessageBox.Show(msg);
     }
    }
    重新编译 修改html代码:添加
    <input type="button" onclick='My_HtmlControl.ShowMessage('Hello World!')' value='Click'>
        访问我们的html页,就是提示不安全信息。
      单击确定之后,我们发现JS报错。根据提示,我们判断可以通过修改IE的设置使控件运行。打开IE的 工具->Internet选项->安全->本地Intranet->自定义级别->对没有标记为安全的ActiveX控件进行初始化和运行,将其值设为启用。我们刷新页面,现在终于可以正确运行了。为什么会报错呢???
        这是因为我们必须要实现IObjectSafety接口,把ActiveX控件标记为安全的ActiveX控件。
    首先我们自己用C#实现这个接口:(在UserControl1.cs中添加)
    public void GetInterfacceSafyOptions(Int32 riid, out Int32 pdwSupportedOptions, out Int32 pdwEnabledOptions) 
    {
    // TOD 添加 WebCamControl.GetInterfacceSafyOptions 实现
    pdwSupportedOptions = 1;
    pdwEnabledOptions = 2;
    }
    public void SetInterfaceSafetyOptions(Int32 riid, Int32 dwOptionsSetMask, Int32 dwEnabledOptions)
    {
    // TOD 添加 WebCamControl.SetInterfaceSafetyOptions 实现
    }
    标记Activex控件为脚本安全1.见Designing Secure ActiveX Controls,这种方法主要适用于ATL Activex控件,最好还是用C++来实现的,相对来说比较麻烦;
    
    2.见Marking Business Objects as Safe for Scripting,选用这种方法,则非常简单了,只需要写入两个注册表项就可以了,如下:
    
    [HKEY_CLASSES_ROOTCLSID<MyActiveXGUID>Implemented 
    Categories{7DD95801-9882-11CF-9FA9-00AA006C42C4}]
    [HKEY_CLASSES_ROOTCLSID<MyActiveXGUID>Implemented 
    Categories{7DD95802-9882-11CF-9FA9-00AA006C42C4}]
    通常ActiveX控件在开发并注册后,一旦在网页中运行,IE并不认为这是一个脚本安全的,会弹出一个IE提示窗口:"An ActiveX control on this page might be unsafe to interact with other parts of the page.Do you want to allow this interaction?"
     重新编译,然后将IE里面的设置改回来在注册表里添加如上两项。现在,我们发现,和JS的交互已经没有问题了。
      这样,一个最基本的ActiveX控件已经写好了。你可以在这个控件的基础上增加任何你需要的功能。到这里,编写控件的任务已经完成了,我们的下一个目标就是发布它。
      首先,我们建立一个windows安装项目,在解决方案中添加新项目【安装项目】
    
    ,并将ActiveX控件的主输出添加到项目输出中
    
    。然后,改动ActiveX控件的主输出文件,将其Register属性改为vsdrpCOM.
    改动项目属性,将引导程序更改为 Web引导程序。很遗憾的是,在 Web引导程序设置 中的安装文件夹URL中必须使用绝对路径,不能使用相对路径。这意味着生成安装程序的时候就必须确定路径,不是很方便。在示例中,我使用了localhost,在发布中可以改为实际的域名。
       现在我们生成安装程序,并把相应得程序拷贝到正确的目录中(本例中为默认网站目录下的ActiveX文件夹中)。我们可以直接执行Setup.Exe文件,以验证安装文件的正确性。在我的机器上正确执行了,成功了!
    
    <object id="My_HtmlControl" classid="clsid:93210714-D354-4E64-96A7-2DA3BE0E16BC" Width="184" Height="96" codebase="ActiveX/Setup.Exe">
    </object>
    codebase="ActiveX/Setup.Exe"
      注意,我们在object块中加入了codebase属性,这就是制定的下载控件的位置,可以使用相对路径。别忙,我们现在还不能正确请求这个页面,因为我们还没有对我们的控件进行签名。签名可以采用两种方式,一种是在上面生成安装程序的时候签名,另一种是使用sn.exe签名。推荐大家使用后者,因为可以提供更多选项。本人很懒,就不多写了,大家可以参考csdn上的文章《发布ActiveX》。先给给大家提个醒,在申请证书的时候选择 高级证书申请。
    检查ActiveXObject是否可用,然后引导用户下载并安装,有朋友问怎么自动下载并安装,个人认为这种做法不太合适,毕竟ActiveX对用户来说是存在风险的,所以我们必须要重视用户的知情权哦。
    var str1 = new Array();
    try
    {
    var axObj=new ActiveXObject("My_HtmlControl.UserControl1d");
    }catch(e){
    str1.push("<span class="red"><a style="color:#f00;" href="/ActiveX/Setup.Exe">请点此安装控件后刷新</a></span>");
    document.write(str1.join(""));
    }
    alert(DetActiveX());
    // 检测系统是否禁用ActiveX 
    function DetActiveX()
    {
    var kXmlHttp = null;   
    try
    {/*非微软IE支持的xmlhttp对象*/
    if (typeof XMLHttpRequest != "undefined")
    {
       kXmlHttp = new XMLHttpRequest();
       return true;
    }
    else/*微软IE支持的xmlhttp对象*/
    {
       var MSie = ["MSXML2.XMLHttp.5.0","MSXML2.XMLHttp.4.0",
          "MSXML2.XMLHttp.3.0","MSXML2.XMLHttp","Microsoft.XMLHttp"];
       for (i in MSie)
       {     
       kXmlHttp = new ActiveXObject(MSie[i]);
       return true;
       }
    }
    }catch(e){}
    
    return false;
    }
    针对网友的要求,完善了一下本文的内容
    如下在安装项目上进行设置即可,在安装软件时注册该组件在注册表中的注册等操作!如下图:
    
    
    
    
    对安装过程中的所有界面和安装流程控制都可以定义了。还有一点就是因为是ActiveX所有,安全认证很关键。他们和淘宝等网站上的插件是一样的。如果想要被通用那么需要认证。建立在信任基础上让客户端安装应该是最简单的解决办法。
     
    View Code
  • 相关阅读:
    软工实践个人总结
    第02组 Beta版本演示
    第02组 Beta冲刺(5/5)
    第02组 Beta冲刺(4/5)
    第02组 Beta冲刺(3/5)
    第02组 Beta冲刺(2/5)
    第02组 Beta冲刺(1/5)
    第02组 Alpha事后诸葛亮
    第02组 Alpha冲刺(6/6)
    第02组 Alpha冲刺(5/6)
  • 原文地址:https://www.cnblogs.com/blogpro/p/11458120.html
Copyright © 2011-2022 走看看