版本比较

标识

  • 该行被添加。
  • 该行被删除。
  • 格式已经改变。

目录

需求来源

本次修改是对原有功能的Shell命令及NetDispatch的替换,原功能存在较多问题

Shell命令

  • 操作不方便
  • 不支持交互式命令
  • 能利用漏洞进入服务器后台,获取root权限等


NetDispatch

  • 连接丢失
  • 服务端程序崩溃退出等


...

功能演示

本地设备的webssh功能本地设备的webssh功能,账号密码与后台ssh的一致。

如果从本地网口的web访问,会跳转到局域网的ip

如果从远端omc访问,会跳转到omc的ip

...

远端omc效果可以看到,从公网访问到了局域网设备(192.168.1.198),并且通过局域网访问了192.168.1.27(编译服务器)

在公网上写文件时,从本地终端也实时刷新了数据


...

实现方法

后端

设备端GatewayServer需增加jsoncmd的解析命令

代码块
	int CWebSSH::Handle(HTTPServerRequest &request, CJSRPCResponseMaker &response, Poco::URI &uri)
	{
		response.BeginResult();
		response.BeginObj(NULL);

 		response.AddMemberString("url", " http://192.168.1.198:8080"); // demo,具体实现较复杂,参看实际代码

		response.EndObj();
		response.EndResult();
		return 0;
	}

	const char *CWebSSH::GetName()
	{
		return "webssh";
	}

前端



本地webssh已经修改成功,需要新增omc上的远程webssh功能


FRPS部署

x86

使用docker部署frps服务端

使用docker部署frpc客户端(x86)

...

代码块
bindAddr = "0.0.0.0"
bindPort = 9000
quicBindPort = 9000

transport.maxPoolCount = 2000
transport.tcpMux = true
transport.tcpMuxKeepaliveInterval = 60
transport.tcpKeepalive = 7200
transport.tls.force = false

webServer.addr = "0.0.0.0"
webServer.port = 9003
webServer.user = "adminxxxxxx"
webServer.password = "msj123xxxxxx"
webServer.pprofEnable = false

log.to = "./frps.log"
log.level = "info"
log.maxDays = 3
log.disablePrintColor = false

auth.method = "token"
auth.token = "msj123"

allowPorts = [
  { start = 60000, end = 65535 }
]

maxPortsPerClient = 1024
udpPacketSize = 1500
natholeAnalysisDataReserveHours = 168

...

代码块
serverAddr = "49.234.66.123"
serverPort = 9000

auth.method = "token"
auth.token = "msj123xxxxx"

webServer.addr = "0.0.0.0"
webServer.port = 9003
webServer.user = "adminxxxxxx"
webServer.password = "msj123xxxxxx"
webServer.pprofEnable = false

[[proxies]]
name = "192.168.1.27-ssh"
type = "tcp"
localIP = "192.168.1.27"
localPort = 22
remotePort = 60120

...

查看服务端控制面板,客户端已经注册成功,并且已经将ssh端口映射到公网使用


客户端可以直接在控制台修改需要映射的端口

Image RemovedImage Added


...

终端设备

终端设备一般为arm或者arm64的平台,整套流程终端设备需要使用到的两个软件为frpc和ttyd

...

编译时候会有报错,修复后编译放到设备上可以正常运行


注意事项

加入了frpc和ttyd的软件包会变大,升级时对空间的要求会高一点,原有的升级方式需要两倍的升级包空间,这个问题在当前版本已经得到优化。但是如果用优化前的系统来升级优化后的系统,如果数据库文件较大,则可能会存在空间不够的问题,需要注意。