Skip to content

dalaolala/webssh

Repository files navigation

WebSSH - 在线SSH终端工具

一个基于Web的SSH终端工具,提供完整的Web版SSH客户端体验。

✨ 核心功能

  • 用户认证: 注册、登录、JWT令牌认证
  • 服务器管理: 服务器增删改查、分组管理
  • SSH终端: 基于xterm.js的Web终端,支持密码和私钥认证
  • 数据安全: AES-256加密存储敏感信息

🚀 快速部署

📦 Docker 一键部署(推荐)

方式一:使用官方镜像(推荐用于生产环境)

docker run -d \
  --name webssh-app \
  -p 3000:3000 \
  -e DB_HOST=your-mysql-host \
  -e DB_PORT=3306 \
  -e DB_USER=webssh_user \
  -e DB_PASSWORD=your-db-password \
  -e DB_NAME=webssh \
  -e JWT_SECRET=your-jwt-secret \
  -e ENCRYPTION_KEY=your-32-byte-encryption-key \
  dalaolala/webssh:latest

导入初始化数据请查看 install.sql

最后两个参数相关密钥生成方法:

# 生成32字节JWT密钥(推荐使用强随机字符串)
openssl rand -base64 32

# 生成32字节加密密钥(必须正好32个字符)
openssl rand -hex 16  # 输出32字符的十六进制字符串

方式二:完整部署脚本(包含MySQL)

# 一键部署(包含Docker环境检查、镜像构建、服务启动)
git clone https://github.com/dalaolala/webssh.git
cd webssh
chmod +x deploy.sh
./deploy.sh

# 部署完成后访问:http://localhost:3000

部署特点:

  • 自动构建多阶段Docker镜像
  • 包含MySQL数据库服务,使用 install.sql 进行数据库初始化
  • 自动生成安全的加密密钥(JWT_SECRET和ENCRYPTION_KEY)
  • 健康检查和服务监控
  • 生产环境配置

🛠️ 手动部署

环境要求: Node.js 16+, MySQL 5.7+

# 1. 克隆项目
git clone https://github.com/dalaolala/webssh.git
cd webssh

# 2. 数据库初始化(使用install.sql脚本)
mysql -u root -p < install.sql

# 3. 安装依赖
npm install

# 4. 环境配置
cp backend/.env.example backend/.env
# 编辑 backend/.env 文件,配置数据库连接和密钥

# 5. 启动应用
npm run dev

# 6. 前后端分别启动
cd frontend
npm run dev:frontend
http://localhost:5173

cd backend
npm run dev:backend
http://localhost:3000

重要说明:

  • 数据库初始化统一使用 install.sql 脚本
  • ENCRYPTION_KEY 必须是正好32字节的字符串
  • 生产环境请使用强密码生成器创建安全的密钥

生成符合要求的密钥:

# 生成32字节JWT密钥
openssl rand -base64 32

# 生成32字节加密密钥(必须正好32个字符)
openssl rand -hex 16

📁 项目结构

webssh/
├── backend/          # Node.js后端服务
├── frontend/         # Vue3前端应用
├── deploy.sh         # Docker部署脚本
├── docker-compose.yml # 容器编排配置
├── Dockerfile        # 容器构建配置
└── install.sql       # 数据库初始化脚本

🔧 技术栈

前端: Vue 3 + Vite + Element Plus + xterm.js
后端: Node.js + Express + Socket.IO + MySQL
部署: Docker + Docker Compose


详细文档请查看 docs/ 目录 数据库设计请查看 install.sql

🔧 使用指南

首次使用

  1. 访问 http://localhost:3000 注册账号
  2. 登录后进入仪表板
  3. 添加你的第一个SSH服务器
  4. 点击服务器名称开始连接

服务器配置

  • 名称: 服务器显示名称
  • 主机: IP地址或域名
  • 端口: SSH端口(默认22)
  • 用户名: SSH登录用户名
  • 认证方式: 密码认证或私钥认证
  • 分组: 服务器分组(可选)

终端操作

  • 连接: 点击"连接"按钮建立SSH会话
  • 命令输入: 在底部输入框输入命令
  • 快捷键:
    • Ctrl+C: 中断当前命令
    • Ctrl+D: 退出会话
    • Ctrl+L: 清屏
  • 断开: 点击"断开"按钮结束连接

快速连接

  • 无需提前配置:直接输入凭据即可发起 SSH / SFTP 连接
  • 独立多标签页架构:每个终端和独立全屏 SFTP 文件管理器都运行在完全隔离的环境中,互不干扰
  • 智能历史与分组:连接信息(包括可选保存的密码)与分组展开状态自动安全保存在当前浏览器本地中
  • 支持导入与导出:一键导出 JSON 格式的快速连接数据,轻松在不同设备间迁移历史

🌐 Nginx 反向代理配置

如需通过 Nginx 将域名/端口转发到 WebSSH(默认运行在 3000 端口),参考以下配置:

server {
    listen 80;
    server_name your-domain.com;  # 替换为你的域名或 IP

    location / {
        # 核心指令:将请求转发到目标地址
        proxy_pass http://127.0.0.1:3000;

        # --- 以下是标准请求头设置 (推荐保留) ---

        # 将客户端真实的 Host 传递给后端
        proxy_set_header Host $host;

        # 传递客户端的真实 IP
        proxy_set_header X-Real-IP $remote_addr;

        # 记录代理链上的 IP
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

        # 告诉后端原本的请求协议是 http 还是 https
        proxy_set_header X-Forwarded-Proto $scheme;

        # --- WebSocket 支持(Socket.IO 必须) ---
        proxy_http_version 1.1;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection "upgrade";
        proxy_read_timeout 86400;  # 长连接超时(秒),SSH 会话期间不断开
    }
}

注意:本项目使用 Socket.IO 建立 WebSocket 长连接来传输 SSH 数据,
必须保留 UpgradeConnection 头,否则终端连接会失败。


🐛 故障排除

常见问题

  • 数据库连接失败: 检查MySQL服务状态和用户权限
  • 加密密钥错误: 确保ENCRYPTION_KEY为32字节
  • 端口冲突: 检查3000和5173端口是否被占用
  • 依赖安装失败: 清除npm缓存后重新安装

日志查看:

# 后端日志
cd backend && npm run dev

# 前端日志  
cd frontend && npm run dev

🤝 贡献指南

  1. Fork 项目
  2. 创建功能分支 (git checkout -b feature/AmazingFeature)
  3. 提交更改 (git commit -m 'Add some AmazingFeature')
  4. 推送到分支 (git push origin feature/AmazingFeature)
  5. 开启 Pull Request

📄 许可证

本项目采用 MIT 许可证 - 查看 LICENSE 文件了解详情

🙏 致谢


注意: 本项目仍在开发中,部分功能可能不完善。生产环境使用前请充分测试。

About

打开浏览器就能用的webssh——带登录、服务器管理和 SFTP,部署一次,随时随地连接你的服务器。

Topics

Resources

Stars

Watchers

Forks

Packages

 
 
 

Contributors

Languages