堡垒机Linux黑屏识别命令Set -n探索可能性

问题

自己根据流拼接命令 ,比如向前向后,<-- --> backspace 这几个按钮符号 如果有变化则代码中不能写死,需要根据配置动态设置。

Xterm 黑屏通过 Websocket 发送数据流给SSH客户端。

数据流如下图:

命令识别 方案参考:揭秘黑屏操作特性,以及不同命令识别方案的比对-CSDN博客

自己根据数据流进行识别,需要根据黑屏的交互维护后端的命令buffer,比如:ls backspace l 结果就是ls,还有:home,end,鼠标向前 向后,以及一些快捷键,并这些快捷键都可以被修改。

常用快捷键,以及快捷键配置inputrc文件,stty命令。详细参考:Linux 黑屏操作快捷键,已经配置修改inputrc stty-CSDN博客

解决方案

方案描述

  1. 自己在代码中拼接命令

  2. 将数据流发送给bash shell,因为最好的命令识别主体是bash,而非自己识别,否则有一致性问题

set -n 不执行

set -n 的作用是解释命令但不执行。 局限于脚本,bash shell交互黑屏set -n是没有效果的,原因:交互shell如果能设置成功,就没法退出交互页面了。

那么启动bash的时候设置-n,这样整个黑屏就没法执行命令。命令:bash -n,输出如下,因为启动bash会获取profile文件PS1环境变量,因为是-n参数没法读取PS1导致输出:bash-4.4 #

PS1='>> ' /bin/bash -n

这个bash-4.4 字符串可能不确定,如果能在启动时设置PS1就不会变了。

bash 复制代码
PS1='>> ' /bin/bash -n

设置SSH用户默认bash

bash 复制代码
[root@iZ2ze6n5mtnyh6st0dxrvqZ ~]# cat /etc/passwd
testuser:x:1001:1002::/home/testuser:/opt/shell/custom_shell.sh

custom_shell.sh文件:

bash 复制代码
[root@iZ2ze6n5mtnyh6st0dxrvqZ shell]# cat custom_shell.sh 
#!/bin/sh

echo "========================================="
echo "Connected: $(date)"
echo "User: $(whoami)"
echo "From: $(echo $SSH_CLIENT | awk '{print $1}')"
echo "========================================="
echo ""
echo "enter terminal..."


/bin/bash -nx
[root@iZ2ze6n5mtnyh6st0dxrvqZ shell]#

用户testuser登录ssh默认执行opt/shell/custom_shell.sh

方案不足

vim 11.txt 文件的数据流不是命令,是不可以发给bash去识别的。需要进行根据 识别码 判断是否为vim文本编辑模式。

相关推荐
Web3探索者2 天前
可视化服务器管理和传统命令行区别是什么?新手教程:Linux 运维到底该用图形界面还是 SSH 命令行?
linux·ssh
zylyehuo2 天前
Linux系统中网线与USB网络共享冲突
linux
荣--2 天前
一键部署不是为了省时间 —— 它是把"买来的 PaaS"变成"自己的平台"的拐点
运维·zabbix·工程化·一键部署·平台化·边界设计
江华森2 天前
动手实战学 Docker — 从零到集群编排完全指南
运维
Avan_菜菜3 天前
FRP 内网穿透完整实战:从 HTTP 映射到 HTTPS 自签代理
运维·nginx·https
Sokach10153 天前
Linux Shell 脚本从零到能用:一个新手的一天学习总结
linux
SelectDB4 天前
Litefuse 开源并推出单进程轻量模式,25 秒就能跑起来的 Agent 可观测与评估平台
运维·后端·自动化运维
AlfredZhao4 天前
Docker 容器时区不对,`timedatectl` 不存在怎么办?
linux·timezone
zzzzzz3105 天前
9K Star 炸裂开源!这个 C 语言写的代码知识图谱,把 Linux 内核索引压缩到了 3 分钟
linux·服务器·sql
XIAOHEZIcode5 天前
Linux系统鼠标偏移常见原因以及修复方案
linux·运维·游戏