写个自己的远程桌面

今天偶然在首页看到了这篇文件http://www.cnblogs.com/mobwiz/p/remote_desktop_share.html,感觉很有意思,一起以来,远程桌面在我心目中是很高大上的,哪想着几行代码就能实现了

自己试了一下,同事那边连了三个连接也没什么问题,和远程桌面效果完全一致。

下面是代码,只为以后自己用到找代码方便,基本来自上面的文章,感谢作者。截图什么的请看原文

 

服务器端代码,请先在引用里面添加rdpcomapi,需要在COM项中才能找到

private void button1_Click(object sender, EventArgs e)
        {
            var _rdpSession = new RDPSession();  // 新建RDP Session

            _rdpSession.OnAttendeeConnected += _rdpSession_OnAttendeeConnected;

            Rectangle rect = new Rectangle();
            rect = Screen.GetWorkingArea(this);

            _rdpSession.SetDesktopSharedRect(rect.X, rect.Y, rect.Right, rect.Bottom); // 设置共享区域,如果不设置默认为整个屏幕,当然如果有多个屏幕,还是设置下主屏幕,否则,区域会很大

            _rdpSession.Open(); // 打开会话

            IRDPSRAPIInvitation invitation = _rdpSession.Invitations.CreateInvitation("baseAuth", "groupName", "", 64);  // 创建申请
            Console.WriteLine(invitation.ConnectionString);
            Clipboard.SetText(invitation.ConnectionString);//最最重要的连接字符串
        }

        //经过测试,这个一定得有,否则连接不上
        private void _rdpSession_OnAttendeeConnected(object pAttendee)
        {
            textBox1.AppendText("有用户连接");
            IRDPSRAPIAttendee att = pAttendee as IRDPSRAPIAttendee;


            att.ControlLevel = CTRL_LEVEL.CTRL_LEVEL_VIEW;//这个一定要有
        }

  

客户端代码,在工具箱中,添加RDP Viewer Class,然后把该控件拖到窗体上

private void button1_Click(object sender, EventArgs e)
{
   //textBox1里面放了连接字符串
     axRDPViewer1.Connect(textBox1.Text, Environment.UserName, "");
}

  

下面是效果图,同时三个连接

转载于:https://www.cnblogs.com/varlxj/p/5181501.html

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我可以帮您远程控制桌面的代码。 首先,您需要在服务器端使用类似于Node.js或其他支持Websocket的服务器端技术来创建一个Websocket服务端。您可以使用WebSocket API来实现与客户端的双向通信。 以下是一个简单的示例代码: 在HTML文件中,您需要引入Vue.js和WebSocket库,然后定义一个Vue实例。 ``` <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>Remote desktop control</title> <script src="https://cdn.jsdelivr.net/npm/vue"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/vue-websocket/3.0.5/vue-websocket.min.js"></script> </head> <body> <div id="app"> <h1>{{ message }}</h1> </div> </body> <script> var vm = new Vue({ el: '#app', data: { message: 'Welcome to remote desktop control' }, websocket: { host: 'ws://yourserver.com:1234', onopen: function () { console.log('Websocket connection established'); }, onmessage: function (event) { // Handle incoming messages from server } } }) </script> </html> ``` 上面的代码中,Vue实例使用了一个名为“websocket”的配置参数,它包含了Websocket连接所需的所有信息。其中,'host'参数是Websocket服务器的地址和端口号,您需要将其替换为您自己的Websocket服务器地址和端口号。 接下来,您需要在服务器端实现远程控制桌面的代码。这里,我推荐使用nodejs的npm库node-rdpjs和node-rdpjs-server。 使用这些库,您可以很容易地将远程桌面连接集成到您的服务器端应用程序中。 以下是一个简单示例代码,在服务器端应用程序中使用node-rdpjs和websockets来启动远程桌面连接。 ``` var rdp = require('node-rdpjs'); var WebSocketServer = require('ws').Server; var rdpServer = rdp.createRdpServer({ screen: { width: 1024, height: 768, depth: 24 } }); rdpServer.on('connect', function(session) { console.log('RDP client connected'); }); rdpServer.on('logon', function(session) { console.log('User logged in', session.username); }); rdpServer.on('sessionEnd', function(session) { console.log('User disconnected'); }); var wss = new WebSocketServer({ port: 1234 }); wss.on('connection', function(ws) { console.log('Websocket client connected'); rdpServer.on('bitmap', function(bitmap) { ws.send(bitmap); }); ws.on('message', function(data) { var message = JSON.parse(data); if (message.type === 'keystroke') { rdpServer.sendKey(message.keyCode, message.down); } else if (message.type === 'mouse') { rdpServer.sendPointerEvent(message.x, message.y, message.buttonMask); } }); }); ``` 上面的代码中,我们创建了一个WebSocketServer并使用了node-rdpjs创建了一个RDP服务器。当RDP客户端连接时,我们向WebSocket客户端发送由远程桌面生成的位图。在收到WebSocket客户端的消息之后,我们将其转发到RDP服务器。 在您的Vue应用程序中,您需要将客户端鼠标和键盘事件转换为WebSocket消息并发送给服务器。以下是如何实现的示例代码: ``` mounted() { document.addEventListener('keydown', (event) => { var message = { type: 'keystroke', keyCode: event.keyCode, down: true }; this.$socket.send(JSON.stringify(message)); }); document.addEventListener('keyup', (event) => { var message = { type: 'keystroke', keyCode: event.keyCode, down: false }; this.$socket.send(JSON.stringify(message)); }); document.addEventListener('mousemove', (event) => { var message = { type: 'mouse', x: event.clientX, y: event.clientY, buttonMask: 0 }; this.$socket.send(JSON.stringify(message)); }); document.addEventListener('mousedown', (event) => { var message = { type: 'mouse', x: event.clientX, y: event.clientY, buttonMask: event.button }; this.$socket.send(JSON.stringify(message)); }); document.addEventListener('mouseup', (event) => { var message = { type: 'mouse', x: event.clientX, y: event.clientY, buttonMask: event.button }; this.$socket.send(JSON.stringify(message)); }); } ``` 以上代码监听键盘和鼠标事件,并将它们转换为WebSocket消息并发送给服务器。 最终,您需要在Vue实例中更新位图,以显示远程桌面的实时图像流。 ``` this.$socket.onmessage = function (event) { var canvas = document.getElementById('canvas'); var ctx = canvas.getContext('2d'); var imageData = new ImageData(new Uint8ClampedArray(event.data), 1024, 768); ctx.putImageData(imageData, 0, 0); }; ``` 上面的代码中,我们将从服务器收到的位图数据绘制到HTML5 canvas上。 希望这能帮助到您!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值