当前位置:
首页 > Python基础教程 >
-
C#教程之自建Socket转发,使用远程桌面(mstsc)连
网络结构图如下:
开题先放图,一切全靠编哈哈。
进入正题!
如图所示,我们需要一个公网服务器,利用公网服务器将内网的数据进行转发,从而实现两个内网服务器的通讯。没错,这不是p2p,原本想做成p2p,因为有点难度,所以先弄一个tcp数据包转发,后面再来打洞进行p2p连接。
开发环境
VS2017 + asp net core2.1 + .net framework 4.5
整个过程是如何实现的呢?
1.被控客户端启动,发送被控端名称,例如:Home
2.服务器接收到被控端的数据,将Home记录,并将Home绑定到当前Tcp连接
3.主控端启动,发送要连接的“被控端服务”名称,例如:Home
4.服务端接收到主控端的请求,查询Home对应的Tcp连接
5.将从主控端来的数据转发到被控端,将被控端来的数据转发到主控端
代码在哪?
放到github上了:https://github.com/bobowire/Wireboy.Socket.P2PService
在实现的过程中遇到什么问题了?
1.由于windows锁屏后,Console.WriteLine方法会进行无限期等待,导致程序卡住不动。
解决办法:在运行后,将所有的Console.WriteLine方法全部注释掉了。
2.在连接一次之后,再次连接会因为接收函数的超时时间太长,导致后面连接失败
解决办法:增加守护线程,在进行数据传输后,开启守护线程,一旦数据传输发生超时,启动新的tcp连接进行通讯。为什么不用自带的超时?嗯,那时候没想到这个东西。
讲解一下代码吧?
代码很简单,主要是用的TcpClient和TcpListener两个类,利用Dictionary绑定Tcp连接与服务名称,所以只允许一台电脑连接被控端。如此一来,被控端的断线重连对数据的转发影响就不大了。
TcpListener类用于监听本地端口。
TcpClient类用于转发数据。
怎么使用?
请查看项目MD文件:https://github.com/bobowire/Wireboy.Socket.P2PService
运行效果图
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比
一款纯 JS 实现的轻量化图片编辑器
关于开发 VS Code 插件遇到的 workbench.scm.
前端设计模式——观察者模式
前端设计模式——中介者模式
创建型-原型模式