使用 ActiveX 在网页内嵌本地程序 ;网页打开上嵌入本地Excel并打开指定文件

1.创建 Windows 窗体控件库项目;

使用 ActiveX 在网页内嵌本地程序 ;网页打开上嵌入本地Excel并打开指定文件

2.修改项目基础配置

     2.1 修改 AssemblyInfo  添加  [assembly: AllowPartiallyTrustedCallers()]   引用 命名空间 System.Security

     使用 ActiveX 在网页内嵌本地程序 ;网页打开上嵌入本地Excel并打开指定文件

    

   2.2 修改项目程序集信息 ,勾选 “ 使程序集com可见 ”

       使用 ActiveX 在网页内嵌本地程序 ;网页打开上嵌入本地Excel并打开指定文件

 2.3 修改生成 输出  勾选 “ 使程序集com可见 ”

    使用 ActiveX 在网页内嵌本地程序 ;网页打开上嵌入本地Excel并打开指定文件

 

3.主代码

using System;
using System.Diagnostics;
using System.Runtime.InteropServices;
using System.Windows.Forms;

namespace Web.Activex.App
{
    [Guid("71A30280-6AB4-4F29-8C23-B340736B4618")]//此Guid 开发者可自己生成 网页嵌入ActiveX时会使用此Guid
    public partial class UserControl1: UserControl, IObjectSafety
    {
        [DllImport("User32.dll ", EntryPoint = "SetParent")]
        private static extern IntPtr SetParent(IntPtr hWndChild, IntPtr hWndNewParent);

        public UserControl1()
        {
            InitializeComponent();
        }

        public void OpenExcel(string fileFullName)
        {
            //第一个参数 powerpnt excel  winword  或其它,开发者按自己需要换其它程序的启动命令
            //第二个参数 打开的具体文件的全路径
            var proces = Process.Start("excel", fileFullName);

            if(proces!=null)
            SetParent((IntPtr) proces.Id, panel1.Handle);//获取打开的程序窗口句柄,与本控件内要放置的控件的句柄
        }


        #region IObjectSafety 接口成员实现(直接拷贝即可)

        private const string _IID_IDispatch = "{00020400-0000-0000-C000-000000000046}";
        private const string _IID_IDispatchEx = "{a6ef9860-c720-11d0-9337-00a0c90dcaa9}";
        private const string _IID_IPersistStorage = "{0000010A-0000-0000-C000-000000000046}";
        private const string _IID_IPersistStream = "{00000109-0000-0000-C000-000000000046}";
        private const string _IID_IPersistPropertyBag = "{37D84F60-42CB-11CE-8135-00AA004BB851}";

        private const int INTERFACESAFE_FOR_UNTRUSTED_CALLER = 0x00000001;
        private const int INTERFACESAFE_FOR_UNTRUSTED_DATA = 0x00000002;
        private const int S_OK = 0;
        private const int E_FAIL = unchecked((int)0x80004005);
        private const int E_NOINTERFACE = unchecked((int)0x80004002);

        private bool _fSafeForScripting = true;
        private bool _fSafeForInitializing = true;

        public int GetInterfaceSafetyOptions(ref Guid riid, ref int pdwSupportedOptions, ref int pdwEnabledOptions)
        {
            int Rslt = E_FAIL;

            string strGUID = riid.ToString("B");
            pdwSupportedOptions = INTERFACESAFE_FOR_UNTRUSTED_CALLER | INTERFACESAFE_FOR_UNTRUSTED_DATA;
            switch (strGUID)
            {
                case _IID_IDispatch:
                case _IID_IDispatchEx:
                    Rslt = S_OK;
                    pdwEnabledOptions = 0;
                    if (_fSafeForScripting == true)
                        pdwEnabledOptions = INTERFACESAFE_FOR_UNTRUSTED_CALLER;
                    break;
                case _IID_IPersistStorage:
                case _IID_IPersistStream:
                case _IID_IPersistPropertyBag:
                    Rslt = S_OK;
                    pdwEnabledOptions = 0;
                    if (_fSafeForInitializing == true)
                        pdwEnabledOptions = INTERFACESAFE_FOR_UNTRUSTED_DATA;
                    break;
                default:
                    Rslt = E_NOINTERFACE;
                    break;
            }

            return Rslt;
        }

        public int SetInterfaceSafetyOptions(ref Guid riid, int dwOptionSetMask, int dwEnabledOptions)
        {
            int Rslt = E_FAIL;
            string strGUID = riid.ToString("B");
            switch (strGUID)
            {
                case _IID_IDispatch:
                case _IID_IDispatchEx:
                    if (((dwEnabledOptions & dwOptionSetMask) == INTERFACESAFE_FOR_UNTRUSTED_CALLER) && (_fSafeForScripting == true))
                        Rslt = S_OK;
                    break;
                case _IID_IPersistStorage:
                case _IID_IPersistStream:
                case _IID_IPersistPropertyBag:
                    if (((dwEnabledOptions & dwOptionSetMask) == INTERFACESAFE_FOR_UNTRUSTED_DATA) && (_fSafeForInitializing == true))
                        Rslt = S_OK;
                    break;
                default:
                    Rslt = E_NOINTERFACE;
                    break;
            }

            return Rslt;
        }

        #endregion
    }

    [ComImport, Guid("1D9AD540-F2C9-4368-8697-C4AAFCCE9C55")]
    [InterfaceType(ComInterfaceType.InterfaceIsIUnknown)]
    public interface IObjectSafety
    {
        [PreserveSig]
        int GetInterfaceSafetyOptions(ref Guid riid, [MarshalAs(UnmanagedType.U4)] ref int pdwSupportedOptions, [MarshalAs(UnmanagedType.U4)] ref int pdwEnabledOptions);

        [PreserveSig()]
        int SetInterfaceSafetyOptions(ref Guid riid, [MarshalAs(UnmanagedType.U4)] int dwOptionSetMask, [MarshalAs(UnmanagedType.U4)] int dwEnabledOptions);

    }
}
 

4.创建ActiveX安装程序

使用 ActiveX 在网页内嵌本地程序 ;网页打开上嵌入本地Excel并打开指定文件

 

使用 ActiveX 在网页内嵌本地程序 ;网页打开上嵌入本地Excel并打开指定文件

使用 ActiveX 在网页内嵌本地程序 ;网页打开上嵌入本地Excel并打开指定文件

使用 ActiveX 在网页内嵌本地程序 ;网页打开上嵌入本地Excel并打开指定文件

5.软件的  代码部分就算完成了, 现在只要生成安装程序,并且安装到计算机就可以使用了,我们省略安装步骤,

 

6.网页调用此控件

<object id="CardAccessor" 
    classid="clsid:71A30280-6AB4-4F29-8C23-B340736B4618"     
    width="0" 
    height="0">
</object>

 

 

var objCard = document.getElementById("CardAccessor");

objCard.OpenExcel("D://1.xlsx")