WebSSH - 网页上的SSH终端(webssh使用教程)
off999 2025-04-08 17:28 15 浏览 0 评论
不少的云服务器的网页后台就能登录服务器,并可以在浏览器上进入命令行交互。能不能在自己也部署一个呢?能不能配置一个更加符合自身需求的网页 SSH 终端呢?或许可以以此做一个更好的运维管理平台?来看看 Python 编写的 WebSSH 吧!
简介
WebSSH,是 huashengdun 在 Github 上开源的 SSH 终端 Web 应用,项目地址为
https://github.com/huashengdun/webssh,目前版本为 1.5.2。WebSSH 使用 Python 编写,基于 tornado、paramiko 和 xterm.js 库,支持用户名密码登录、密钥登陆和双因素认证,命令行窗口支持全屏且可改变大小,并支持主流的现代浏览器。
安装
WebSSH 要求 Python2.7 或 3.4+。如果有 Python 环境,可以使用 pip 进行安装:
pip install webssh
也可以使用 Docker 运行,下载源码后在项目根目录运行
docker-compose up
即可使用项目所包含的 docker-compose.yml 进行运行部署运行。
示例
WebSSH 在安装完成后,可以直接执行
wssh
运行服务,此时服务默认运行在 127.0.0.1:8888,可以进行访问,显示的是一个 SSH 登录界面:
可以看到,登录的表单输入包括了主机、密码、用户名、密码、密钥、口令短语和一次性密码的输入,用户可以根据自身所需的登录验证方式进行输入,最后点击 Connect 进行连接。连接成功后,网页就会显示所登录的命令行界面:
命令行界面由 xterm.js 渲染,十分美观实用。
WebSSH 还提供了命令行参数来进行配置:
# 在主机2.2.2.2和端口8000上启动服务
wssh --address='2.2.2.2' --port=8000
# 启动一个HTTPS服务,指定证书和私钥
wssh --certfile='/path/to/cert.crt' --keyfile='/path/to/cert.key'
# 对于不在known_hosts上的主机的登录进行拒绝
wssh --policy=reject
# 设置日志等级为debug
wssh --logging=debug
# 指定日志文件
wssh --log-file-prefix=main.log
# 帮助,更多选项
wssh --help
如果对命令行的字体不满意,可以把新的字体文件放置在 webssh/static/css/fonts/ 中进行修改。
此外,WebSSH 支持使用 URL 参数进行登录,和进行命令行窗口的外观设置:
- 传递主机、端口、用户名和 base64 编码的密码进行登录
http://localhost:8888/?hostname=xx&username=yy&password=str_base64_encoded
- 设置命令行背景颜色
http://localhost:8888/#bgcolor=green
- 设置命令行标题
http://localhost:8888/?title=my-ssh-server
- 设置命令行字符编码
http://localhost:8888/#encoding=gbk
- 设置登录后马上执行的命令
http://localhost:8888/?command=pwd
- 设置命令行类型
http://localhost:8888/?term=xterm-256color
部署
可以使用 Nginx 进行反向代理,
wssh --address='127.0.0.1' --port=8888 --policy=reject
# Nginx配置
location / {
proxy_pass http://127.0.0.1:8888;
proxy_http_version 1.1;
proxy_read_timeout 300;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Real-PORT $remote_port;
}
也可以直接部署为独立服务。
wssh --port=8080 --sslport=4433 --certfile='cert.crt' --keyfile='cert.key' --xheaders=False --policy=reject
注意为了安全考虑,部署时要使用 SSL 加密,且一般设置 policy 为 reject,拒绝不在 known_hosts 上的主机连接。
WebSSH 项目的作者在其个人主页上进行了部署,可以进行试用参考。
总结
作为一个网页 SSH 终端,WebSSH 功能齐全,美观实用,部署简单,可以快速实现 SSH 登录功能。WebSSH 支持大量的个性化配置,可以调配适合自己审美的界面。同时 WebSSH 使用 Python 开发,易于进行二次开发,便于添加扩展功能;后端使用了 tornado 框架,在性能上也可以放心。
WebSSH 是一个典型的 Web 应用,代码简洁,功能清晰,是一个值得参考的 Python 开发的 Web 应用项目。感兴趣的开发者可以在其基础上开发插件,实现更多功能。
相关推荐
- python入门到脱坑经典案例—清空列表
-
在Python中,清空列表是一个基础但重要的操作。clear()方法是最直接的方式,但还有其他方法也可以实现相同效果。以下是详细说明:1.使用clear()方法(Python3.3+推荐)...
- python中元组,列表,字典,集合删除项目方式的归纳
-
九三,君子终日乾乾,夕惕若,厉无咎。在使用python过程中会经常遇到这四种集合数据类型,今天就对这四种集合数据类型中删除项目的操作做个总结性的归纳。列表(List)是一种有序和可更改的集合。允许重复...
- Linux 下海量文件删除方法效率对比,最慢的竟然是 rm
-
Linux下海量文件删除方法效率对比,本次参赛选手一共6位,分别是:rm、find、findwithdelete、rsync、Python、Perl.首先建立50万个文件$testfor...
- 数据结构与算法——链式存储(链表)的插入及删除,
-
持续分享嵌入式技术,操作系统,算法,c语言/python等,欢迎小友关注支持上篇文章我们讲述了链表的基本概念及一些查找遍历的方法,本篇我们主要将一下链表的插入删除操作,以及采用堆栈方式如何创建链表。链...
- Python自动化:openpyxl写入数据,插入删除行列等基础操作
-
importopenpyxlwb=openpyxl.load_workbook("example1.xlsx")sh=wb['Sheet1']写入数据#...
- 在Linux下软件的安装与卸载(linux里的程序的安装与卸载命令)
-
通过apt安装/协助软件apt是AdvancedPackagingTool,是Linux下的一款安装包管理工具可以在终端中方便的安装/卸载/更新软件包命令使用格式:安装软件:sudoapt...
- Python 批量卸载关联包 pip-autoremove
-
pip工具在安装扩展包的时候会自动安装依赖的关联包,但是卸载时只删除单个包,无法卸载关联的包。pip-autoremove就是为了解决卸载关联包的问题。安装方法通过下面的命令安装:pipinsta...
- 用Python在Word文档中插入和删除文本框
-
在当今自动化办公需求日益增长的背景下,通过编程手段动态管理Word文档中的文本框元素已成为提升工作效率的关键技术路径。文本框作为文档排版中灵活的内容容器,既能承载多模态信息(如文字、图像),又可实现独...
- Python 从列表中删除值的多种实用方法详解
-
#Python从列表中删除值的多种实用方法详解在Python编程中,列表(List)是一种常用的数据结构,具有动态可变的特性。当我们需要从列表中删除元素时,根据不同的场景(如按值删除、按索引删除、...
- Python 中的前缀删除操作全指南(python删除前导0)
-
1.字符串前缀删除1.1使用内置方法Python提供了几种内置方法来处理字符串前缀的删除:#1.使用removeprefix()方法(Python3.9+)text="...
- 每天学点Python知识:如何删除空白
-
在Python中,删除空白可以分为几种不同的情况,常见的是针对字符串或列表中空白字符的处理。一、删除字符串中的空白1.删除字符串两端的空白(空格、\t、\n等)使用.strip()方法:s...
- Linux系统自带Python2&yum的卸载及重装
-
写在前面事情的起因是我昨天在测试Linux安装Python3的shell脚本时,需要卸载Python3重新安装一遍。但是通过如下命令卸载python3时,少写了个3,不小心将系统自带的python2也...
- 如何使用Python将多个excel文件数据快速汇总?
-
在数据分析和处理的过程中,Excel文件是我们经常会遇到的数据格式之一。本文将通过一个具体的示例,展示如何使用Python和Pandas库来读取、合并和处理多个Excel文件的数据,并最终生成一个包含...
- 【第三弹】用Python实现Excel的vlookup功能
-
今天继续用pandas实现Excel的vlookup功能,假设我们的2个表长成这样:我们希望把Sheet2的部门匹在Sheet1的最后一列。话不多说,先上代码:importpandasaspd...
- python中pandas读取excel单列及连续多列数据
-
案例:想获取test.xls中C列、H列以后(当H列后列数未知时)的所有数据。importpandasaspdfile_name=r'D:\test.xls'#表格绝对...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python自定义函数 (53)
- python进度条 (67)
- python吧 (67)
- python字典遍历 (54)
- python的for循环 (65)
- python格式化字符串 (61)
- python串口编程 (60)
- python读取文件夹下所有文件 (59)
- java调用python脚本 (56)
- python操作mysql数据库 (66)
- python字典增加键值对 (53)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python人脸识别 (54)
- python多态 (60)
- python命令行参数 (53)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)