# README
VncProxy

VncProxy简介
VncProxy
是使用Golang
实现的Vnc
远程桌面代理组件,完全解析rfb
协议,支持远程桌面代理,rbs文件录屏,rbs文件回放,截图,录制视频.
- 全协议支持的vnc proxy。
- 支持Tcp代理
- 支持Websocket代理
- 屏幕录像,保存为
RBS
文件 - 重播服务器,支持vnc客户端链接,播放
RBS
文件。 - 支持实时录制视频
- 支持通过
RBS
文件录制视频。 - 支持屏幕截图
支持的编码格式
- Raw
- CopyRect
- CoRRE
- rre
- Hextile
- Tight
- TightPng
- ZLib
- Zrle
- CursorPseudo
- CursorWithAlphaPseudo
- DesktopNamePseudo
- DesktopSizePseudo
- ExtendedDesktopSizePseudo
- LedStatePseudo
- CursorPosPseudo
- XCursorPseudo
- jpeg
- jrle
- trle
组件说明
Proxy
- 启动
server
接受vnc viewer
的链接. - 启动
client
连接到指定的vnc server
. - 为
vnc viewer
和vnc server
之间建立起消息转发通道。 - 因为
rfb
协议被完全解析,可以针对通信的消息进行转发处理,产生了后续的功能。
Recorder
- 启动
client
连接到指定的vnc server
. - 发送帧缓冲区更新消息
FramebufferUpdateRequest
到vnc server
。 - 处理
vnc server
回复的界面更新消息FramebufferUpdate
。 - 把这一过程以
rbs
文件格式记录下来。
Player
- 启动
server
接受vnc viewer
的链接. - 读取
rbs
文件,并按格式生成FramebufferUpdate
消息发送给vnc viewer
。 vnc viewer
的界面就会回放动作。
Video
- 支持
Proxy
,Recorder
和rbs
文件作为输入源。 - 把
FramebufferUpdate
消息转换为视频文件。
Screenshot
- 支持
Proxy
,Recorder
和rbs
文件作为输入源。 - 把当前的界面视图转换为图片文件。
使用说明
vncProxy
项目有多种应用场景。
可以作为单独的应用程序编译,也可以作为库被其他应用程序引用。
接下来,分别介绍各种场景下的使用方式。
编译
# 使用方式:
# build.sh [-s app_name] [-v version] [-g go_bin]
# app_name 需要编译的应用名称
# 选项: proxy,player,recorder,video,screenshot.
# 默认是所有应用,多个应用可以逗号分割.
# version 编译后的文件版本号,默认为当前git的commit id.
# go_bin 使用的golang程序
# 编译所有应用
$ ./build
# 编译proxy
$ ./build -s proxy -v v0.1.0
# 编译player,recorder
$ ./build -s player,recorder -v v0.1.0
编译后的二进制文件在./bin/
目录
Proxy
代码路径在./cmd/proxy
,如果单独编译该组件,也可以到该目录下自行执行go build
命令编译
获取帮助信息
# 查看帮助信息
$ ./proxy --help
# 查看版本信息
$ ./proxy version
启动tcp服务
# 启动tcp server接受vnc viewer的连接
# vncHost vnc服务器host
# vncPort vnc服务器port
# vncPassword vnc服务器密码
# tcpHost 本地监听的地址
# tcpPort 本地监听的端口
# proxyPassword vnc连接的密码
# debug 使用debug模式启动服务
$ ./proxy start tcpServer --vncHost=192.168.1.2 \
--vncPort=5901 \
--vncPassword=vprix \
--tcpHost=0.0.0.0 \
--tcpPort=8989 \
--proxyPassword=12345612 \
--debug
启动WebSocket服务
# 启动ws server接受novnc的连接
# vncHost vnc服务器host
# vncPort vnc服务器port
# vncPassword vnc服务器密码
# wsHost 本地监听的地址
# wsPort 本地监听的端口
# wsPath websocket连接的地址
# proxyPassword vnc连接的密码
# debug 使用debug模式启动服务
$ ./proxy start wsServer --vncHost=192.168.1.2 \
--vncPort=5901 \
--vncPassword=vprix \
--wsHost=0.0.0.0 \
--wsPort=8988 \
--wsPath=/websockify \
--proxyPassword=12345612 \
--debug
Recorder
代码路径在./cmd/recorder
,如果单独编译该组件,也可以到该目录下自行执行go build
命令编译
获取帮助信息
# 查看帮助信息
$ ./recorder --help
# 查看版本信息
$ ./recorder version
启动Recorder服务
# rbsFile 要保存的rbs文件路径(必填)
# vncHost vnc服务器host
# vncPort vnc服务器port
# vncPassword vnc服务器密码
# debug 使用debug模式启动服务
$ ./recorder start --rbsFile=/path/to/foo.rbs
--vncHost=192.168.1.2
--vncPort=5901
--vncPassword=vprix
--debug
Player
代码路径在./cmd/player
,如果单独编译该组件,也可以到该目录下自行执行go build
命令编译
获取帮助信息
# 查看帮助信息
$ ./player --help
# 查看版本信息
$ ./player version
启动Player Tcp服务
# rbsFile 要保存的rbs文件路径(必填)
# tcpHost 本地监听的tcp协议地址 默认0.0.0.0
# tcpPort 本地监听的tcp协议端口 默认8989
# proxyPassword 连接到proxy的密码 不传入密码则使用auth none
# debug 使用debug模式启动服务
$ ./player start tcpServer --rbsFile=/path/to/foo.rbs
--tcpHost=0.0.0.0
--tcpPort=8989
--proxyPassword=12345612
--debug
启动Player WS服务
# rbsFile 要保存的rbs文件路径(必填)
# wsHost 启动websocket服务的本地地址 默认 0.0.0.0
# wsPort 启动websocket服务的本地端口 默认8988
# wsPath 启动websocket服务的url path 默认'/'
# proxyPassword 连接到proxy的密码 不传入密码则使用auth none
# debug 使用debug模式启动服务
$ ./player start wsServer --rbsFile=/path/to/foo.rbs
--wsHost=0.0.0.0
--wsPort=8989
--wsPath=/
--proxyPassword=12345612
--debug
Screenshot
代码路径在./cmd/screenshot
,如果单独编译该组件,也可以到该目录下自行执行go build
命令编译
获取帮助信息
# 查看帮助信息
$ ./screenshot --help
# 查看版本信息
$ ./screenshot version
启动Screenshot 获取vnc服务器的屏幕截图
# imageFile 要生成的截图地址,暂时只支持jpeg格式(必填)
# vncHost 要连接的vnc服务端地址(必填)
# vncPort 要连接的vnc服务端端口(必填)
# vncPassword 要连接的vnc服务端密码,不传则使用auth none
$ ./screenshot --imageFile=./screen.jpeg --vncHost=127.0.0.1 --vncPort=5900 --vncPassword=12345612
项目参考
本项目参考了以下项目完成。
交流
我在做这个项目的过程中碰到了很多问题,查遍了互联网,缺少中文资料,大部分信息都是雷同的。 所以我萌生了开源的想法,帮助更多有需要的人。
我建立了一个可供交流的微信群,以便大家在使用的过程中碰到疑问,能有解答的地方。 当然,如果你对vnc有兴趣,也可以加我微信,多多交流。 欢迎各位贡献代码。
# Packages
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author