web端访问远程桌面

一、C#制作activeX控件   

二、给activeX控件创建安装包

三、给activeX安装包创建cab包。

四、web端通过object控件访问。

五、设置IE浏览器。

一、C#制作activeX控件   

1、创建一个windows窗体控件库,如下图

web端访问远程桌面_第1张图片

2、选择创建项目属性,弹出如下图:

web端访问远程桌面_第2张图片

3、点击程序集信息,设置式程序集COM可见。

web端访问远程桌面_第3张图片

4、选择生成,为COM互操作注册

web端访问远程桌面_第4张图片

5、创建一个接口IObjectSafety:接口代码如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Runtime.InteropServices;
namespace TestActiveX
{
    [ComImport, GuidAttribute("BD02D776-2A15-4655-BAF3-A42A54989C91")]
    [InterfaceTypeAttribute(ComInterfaceType.InterfaceIsIUnknown)]
    interface Interface1
    {
        [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);
    }
}


6、用户控件界面,两个按钮,一个连接,一个断开,一个远程连接的控件 ,添加远程连接控件需要添加引用如下:

web端访问远程桌面_第5张图片

连接代码、断开代码

 

 //1.手工登录
   // axMsRdpClientNotSafeForScripting1.Server = "192.168.0.10";
   // axMsRdpClientNotSafeForScripting1.AdvancedSettings2.RDPPort = 3389;
   // axMsRdpClientNotSafeForScripting1.Connect();

//自动登录

            axMsRdpClient6NotSafeForScripting1.Server = "222.244.147.170";
            axMsRdpClient6NotSafeForScripting1.AdvancedSettings2.RDPPort = 3389;
            axMsRdpClient6NotSafeForScripting1.UserName = "Administrator";
          
            axMsRdpClient6NotSafeForScripting1.AdvancedSettings2.ClearTextPassword = "aaaaaaa";
            
            //var clientNonScriptable =  axMsRdpClient6NotSafeForScripting1.GetOcx();
            //注意:一定要把EnableCredSspSupport属性置为ture 否则连接上去就是一片空白!
            axMsRdpClient6NotSafeForScripting1.AdvancedSettings7.EnableCredSspSupport = true;

            axMsRdpClient6NotSafeForScripting1.Connect();



断开的代码如下:

      axMsRdpClient6NotSafeForScripting1.Disconnect();

在用户控件里面继承此接口,接口代码如下:

#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

7、给用户控件的类创建GUID ,此处的GUID ,在web端的object clsid式一致的

web端访问远程桌面_第6张图片

把创建的GUID,复制放到用户控件类上面,需引用命名空间System.Runtime.InteropServices,如下图:

 

web端访问远程桌面_第7张图片

 

生成此项目

二、给activeX控件创建安装包

1、创建

web端访问远程桌面_第8张图片

web端访问远程桌面_第9张图片

2、选择安装项目、Add->项目输出

web端访问远程桌面_第10张图片

项目选择创建的windows窗体控件库

web端访问远程桌面_第11张图片

生成这个项目安装包

三、给activeX安装包创建cab包。

 

1、创建CAB Project

web端访问远程桌面_第12张图片

 

选择刚刚创建的CABProject ,Add——》项目输出

web端访问远程桌面_第13张图片

选择刚刚创建的安装包项目

web端访问远程桌面_第14张图片

确定,生成此项目,在Debug下就亦生成胡cab包。

四、web端通过object控件访问。

 

 
            

clsid需要等于用户控件上的GUID。

web端访问远程桌面_第15张图片

 

判断浏览器端是否检测到的 ActiveX控件代码

       

 

五、设置IE浏览器。

1、打开Internet Explorer---菜单栏点“工具”---Internet选项--安全---自定义级别---安全设置---“ActiveX控件和插件下”的第5个“下载未签名的ActiveX控件”选择“提示”---确定!

刷新您要安装的页面即可(因为使用的软件没有通过微软的徽标认证,在SP2中默认是不允许安装这样的程序的,解决方法为
开始-控制面板-系统-硬件。其中在驱动程序项里有有个“驱动程序签名”的选项,点开后。选第一项:忽略—安装软件,不用征求我的意见。)

2、打开Internet Explorer---菜单栏点“工具”---Internet选项--安全---自定义级别---把里面所有禁用的全部改为启用。

3、打开Internet Explorer---菜单栏点“工具”---Internet选项---高级选项里面选择"允许运行和安装软件,即使签名无效”

4、打开Internet Explorer---菜单栏点“工具”---Internet选项--安全---受信任的站点---把该网站添加进去(注意把https改为http)

 

web端访问效果如下:

web端访问远程桌面_第16张图片

 

 

 

 

你可能感兴趣的:(HTML)