根据您的终端的macaddr,通过Web访问您的处在NAT或防火墙里面的终端。
它由客户端和服务端组成。服务端采用GO语言实现, 以及使用了vue+iview。你可以基于你设置的设备ID(不设置则为设备的MAC地址)通过Web浏览器访问你的任意一台终端。
rtty非常适合远程维护你的或者你公司的部署在全球各地的成千上万的Linux设备。
请保持关注以获取最新的项目动态
为了您的安全,强烈建议您使用SSL
- 部署简单,使用方便
- 反向代理
- 根据你设置的ID连接你的设备
- 基于Xterm.js的全功能终端
- 支持SSL: openssl, mbedtls, CyaSSl(wolfssl)
- 支持上传文件到设备
- 支持从设备下载文件
- 支持远程执行命令
- 跨平台: Linux, OpenWrt/LEDE
- libubox - 用于OpenWrt的C工具函数库,但也可以用于其他Linux系统中.参考
- libuwsc - 一个轻量的针对嵌入式Linux的基于libubox的WebSocket客户端C库。
- protobuf-c: - Protocol Buffers的C语言实现
- ustream-ssl - 如果你需要支持SSL
- mbedtls - 如果你选择mbedtls作为你的SSL后端
- CyaSSl(wolfssl) - 如果你选择wolfssl作为你的SSL后端
- openssl - 如果你选择openssl作为你的SSL后端
安装
wget -qO- https://raw.githubusercontent.com/zhaojh329/rtty/master/tools/install.sh | sudo bash
运行RTTY(将下面的参数替换为你自己的参数)
sudo rtty -I 'My-device-ID' -h 'your-server' -p 5912 -a -v -s -d 'My Device Description'
你需要自行交叉编译
使用你的Web浏览器访问你的服务器: https://your-server-host:5912
,然后点击连接按钮。
你可以非常方便的将RTTY嵌入到你现有的平台: https://your-server-host:5912/#/?id=your-id
自动登录: https://your-server:5912/#/?id=device-id&username=device-username&password=device-password
请点击鼠标右键
curl -k https://your-server:5912/cmd -d '{"devid":"test","username":"test","password":"123456","cmd":"ls","params":["/"],"env":{}}'
{"Err":0,"msg":"","code":0,"stdout":"bin\ndev\netc\nlib\nmnt\noverlay\nproc\nrom\nroot\nsbin\nsys\ntmp\nusr\nvar\nwww\n","stderr":""}
var data = {devid: 'test', username: 'test', password: '123456', cmd: 'ls', params: ['/'], env: {}};
$.post('https://your-server:5912/cmd', JSON.stringify(data), function(r) {console.log(r)});
var data = {devid: 'test', username: 'test', password: '123456', cmd: 'ls', params: ['/'], env: {}};
axios.post('https://your-server:5912/cmd', JSON.stringify(data)).then(function (response) {
console.log(response.data);
}).catch(function (error) {
console.log(error);
});
如果你想帮助rtty变得更好,请参考 CONTRIBUTING_ZH.md。
QQ群:153530783