WanWanYun 503a760b17 feat: 添加独立的SSL证书管理模式
新增功能:
- 新增 --ssl/--cert/ssl 命令行参数
- 交互式菜单添加 [5] SSL证书管理 选项
- 可单独配置/更换/续签SSL证书,无需重新部署整个项目

使用场景:
1. 初次部署时选择了"暂不配置HTTPS",现在想添加证书
2. 现有证书即将过期,需要续签(虽然有自动续期,但也可手动)
3. 想更换SSL方案(例如从Certbot换到acme.sh)
4. 想更换域名的SSL证书
5. 想移除HTTPS配置,改回HTTP模式

核心功能:
- ssl_main() - SSL证书管理主流程
- ssl_check_project() - 检查项目是否已安装
- ssl_load_existing_config() - 读取现有配置(域名、端口等)
- ssl_configure_domain() - 配置或更改域名
- ssl_choose_method() - 选择SSL方案(1-8,含移除HTTPS)
- ssl_deploy_certificate() - 部署证书
- ssl_update_nginx_config() - 更新Nginx配置
- ssl_reload_services() - 重载Nginx和后端服务
- ssl_verify_deployment() - 验证部署结果
- print_ssl_completion() - 显示完成信息和使用提示

使用方法:
# 方法1: 命令行参数
bash install.sh --ssl

# 方法2: 交互式菜单
bash install.sh
> 选择 [5] SSL证书管理

# 方法3: 别名
bash install.sh --cert

工作流程:
1. 检查项目是否已安装
2. 读取现有Nginx配置(HTTP/HTTPS端口、域名)
3. 确认或修改域名配置
4. 选择SSL证书方案(支持所有8种方案)
5. 先配置HTTP模式(Let's Encrypt验证需要)
6. 申请/部署SSL证书
7. 更新Nginx为HTTPS配置(或保持HTTP,如果选择8)
8. 重载Nginx和后端服务
9. 验证部署并显示证书信息

特殊选项:
- [8] 移除HTTPS配置 - 将HTTPS站点改回HTTP模式
- [0] 取消操作 - 不做任何修改

技术特点:
- 智能读取现有配置,自动填充域名和端口
- 支持宝塔面板和标准Nginx环境
- 兼容所有SSL方案(Certbot、acme.sh系列、手动证书)
- 自动处理证书路径和Nginx配置
- 显示证书有效期信息

影响范围:
- install.sh 新增 ~450 行代码
- 添加 9 个新函数
- 更新交互式菜单和命令行帮助
2025-11-13 13:56:06 +08:00

玩玩云 - Web SFTP 文件管理系统

一个基于Web的SFTP文件管理系统提供文件上传、下载、分享等功能支持多用户管理。

📋 项目简介

玩玩云是一个现代化的Web文件管理系统,让您可以通过浏览器管理SFTP服务器上的文件。系统支持文件的上传、下载、重命名、删除、分享等操作并提供桌面端上传工具方便快速上传大文件。

主要特性

  • 文件管理 - 浏览、上传、下载、重命名、删除文件
  • 文件分享 - 生成分享链接,支持密码保护和有效期设置
  • 多用户系统 - 用户注册、登录、权限管理
  • 桌面上传工具 - 拖拽上传,实时显示进度
  • 流式下载 - 服务器零存储,纯中转下载
  • 管理员功能 - 用户管理、文件审查、系统设置
  • Docker部署 - 一键部署,易于维护

🛠️ 技术栈

前端

  • Vue.js 3 - 渐进式JavaScript框架
  • Axios - HTTP请求库
  • Font Awesome - 图标库

后端

  • Node.js 20 - JavaScript运行时
  • Express - Web应用框架
  • better-sqlite3 - 轻量级数据库
  • ssh2-sftp-client - SFTP客户端
  • JWT - 用户认证

部署

  • Docker - 容器化
  • Docker Compose - 容器编排
  • Nginx - 反向代理

🚀 快速开始

环境要求

  • Docker: 20.10.0+
  • Docker Compose: 2.0.0+
  • 操作系统: Linux (Ubuntu 20.04+ / Debian 10+ / CentOS 7+)
  • 内存: 最低 1GB RAM推荐 2GB+

方法1: 一键部署(推荐)

# 1. 上传或克隆项目
cd /var/www
# 将项目文件上传到此目录

# 2. 进入项目目录
cd ftp-web-manager

# 3. 一键部署
bash deploy.sh

deploy.sh脚本会自动

  • 检查Docker和Docker Compose环境
  • 创建必要的目录
  • 构建并启动所有服务
  • 显示访问信息和默认账号

方法2: 手动部署

# 1. 进入项目目录
cd /var/www/ftp-web-manager

# 2. 创建必要的目录
mkdir -p certbot/conf certbot/www backend/uploads

# 3. 构建并启动服务
docker-compose up --build -d

# 4. 查看日志
docker-compose logs -f

访问系统

部署完成后:

📖 使用教程

配置SFTP服务器

首次使用需要配置SFTP连接信息

  1. 登录后点击右上角用户菜单

  2. 选择"设置"

  3. 填写SFTP配置

    • SFTP主机: 您的SFTP服务器IP
    • SFTP端口: 默认22
    • SFTP用户名: SFTP账号
    • SFTP密码: SFTP密码
    • HTTP下载基础URL(可选): 如果有HTTP直接下载地址
  4. 点击"保存配置"

文件管理

  • 浏览文件: 点击文件夹图标进入子目录
  • 上传文件: 点击"上传文件"按钮选择本地文件
  • 下载文件: 点击文件行的下载按钮
  • 重命名: 点击"重命名"按钮修改文件名
  • 删除: 点击"删除"按钮删除文件

文件分享

  1. 点击文件行的"分享"按钮
  2. 设置分享选项:
    • 分享密码(可选)
    • 有效期(可选)
  3. 复制分享链接发送给他人

🔧 维护操作

查看日志

# 查看所有日志
docker-compose logs -f

# 查看后端日志
docker-compose logs -f backend

重启服务

# 重启所有容器
docker-compose restart

# 重启指定容器
docker-compose restart backend

停止服务

docker-compose down

备份数据

# 备份数据库
cp backend/ftp-manager.db backup/ftp-manager.db.$(date +%Y%m%d)

# 备份整个项目
tar -czf backup/wanwanyun-$(date +%Y%m%d).tar.gz .

更新代码

# 拉取最新代码
git pull

# 重新构建并重启
docker-compose up --build -d

🔐 安全建议

  1. 修改默认密码: 首次登录后立即修改admin密码
  2. 使用HTTPS: 配置SSL证书使用HTTPS访问
  3. 修改JWT密钥: 在backend/.env文件中设置随机的JWT_SECRET
  4. 定期备份: 定期备份数据库文件
  5. 限制端口: 不要对外暴露40001端口只通过Nginx访问

常见问题

Docker容器启动失败

# 查看日志
docker-compose logs backend

# 重新构建
docker-compose down
docker-compose up --build -d

上传失败提示权限错误

检查SFTP服务器目录权限确保上传目录有写权限。

分享链接无法访问

检查nginx配置和防火墙设置确保端口8080可访问。

📁 项目结构

ftp-web-manager/
├── backend/              # 后端代码
│   ├── server.js        # 主服务器文件
│   ├── database.js      # 数据库操作
│   ├── auth.js          # 认证中间件
│   ├── Dockerfile       # Docker镜像
│   └── package.json     # 依赖配置
│
├── frontend/            # 前端代码
│   ├── index.html      # 登录页面
│   ├── app.html        # 主应用页面
│   ├── share.html      # 分享页面
│   └── libs/           # 第三方库
│
├── nginx/               # Nginx配置
│   └── nginx.conf      # 配置文件
│
├── upload-tool/         # 上传工具
│   ├── upload_tool.py  # Python源码
│   └── build.bat       # 打包脚本
│
├── docker-compose.yml   # Docker编排
├── deploy.sh           # 一键部署脚本
├── .gitignore          # Git忽略文件
└── README.md           # 本文件

🤝 贡献指南

欢迎提交Issue和Pull Request

📄 许可证

本项目仅供学习和个人使用。


玩玩云 - 让文件管理更简单 ☁️

Description
No description provided
Readme 17 MiB
Languages
JavaScript 74.5%
HTML 14.9%
Shell 10.5%