web端访问远程桌面

一、C#制作activeX控件   

二、给activeX控件创建安装包

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

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

五、设置IE浏览器。

一、C#制作activeX控件   

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

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

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

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

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、用户控件界面,两个按钮,一个连接,一个断开,一个远程连接的控件 ,添加远程连接控件需要添加引用如下:

连接代码、断开代码

 

 //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式一致的

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

 

 

生成此项目

二、给activeX控件创建安装包

1、创建

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

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

生成这个项目安装包

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

 

1、创建CAB Project

 

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

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

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

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

 

 <object id="Object2" classid="clsid:DB7FC8EA-E17A-479B-9E56-075015170C5A"
                     style="background-color:black;width:100%;height:1000px;" codebase="/lib/RemoteExpert/CABProject.CAB#version=1,0,0,0">
            </object>

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

 

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

       <input type="button" value="点击" onclick="aa()" />

<script>
    function aa() {
        var objCard = document.getElementById("Object2");

        if (objCard.object == null) {
            alert("Object1插件未安装!");
        }
        else {
            alert("已检测到Object1插件!");
        }
    }
    $(function () {


    });
</script>

 

五、设置IE浏览器。

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

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

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

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

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

 

web端访问效果如下:

 

 

 

 

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值