堡垒机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文本编辑模式。

相关推荐
寺中人2 小时前
基于Linux实现SSH密钥免密登录完整实战教程(CentOS/Ubuntu通用)
linux·ssh·免密登录·服务器运维·ssh-keygen
lilihuigz2 小时前
从“拥有AEO工具”到“拥有AEO代理”:三层架构解决营销自动化瓶颈 - 易服客工作室
运维·自动化
有想法的py工程师2 小时前
手工处理 Oracle Cloud ARM 实例在线 DD Rocky Linux 10报错
linux·arm开发·oracle
万粉变现经纪人3 小时前
2026最新Windows11系统CMD安装Claude Code 快速接入DeepSeek V4 Pro在VSCode编程工具中使用保姆级入门教程指南
linux·运维·ide·windows·vscode·macos·编辑器
木雷坞3 小时前
自托管 n8n:Docker Compose、Webhook 和升级备份排查
运维·容器
少威shaowei3 小时前
在 Mac 上搭建 DNS 服务器
运维·服务器·macos
wxmtwfx3 小时前
Linux 系统内核列表宏解析
linux·list·列表
utf8mb4安全女神3 小时前
shell脚本
linux·运维·服务器
天一生水water3 小时前
agent教程S01-Agent 最小循环教程整理
java·服务器·网络·agent