WanWanYun e10ff04166 feat: 优化更新流程 - 添加保留上传工具选项
问题背景:
- 之前每次更新都会删除并重新下载上传工具(43MB)
- 重新下载耗时长(1-2分钟),且可能因网络问题失败
- 但如果不删除,万一上传工具有更新也无法获取

优化方案:
在更新流程中添加用户选择:

更新上传工具逻辑:
1. 检测是否已存在上传工具可执行文件
2. 验证文件大小(>30MB为有效)
3. 如果存在有效工具,显示选择菜单:

   ╔════════════════════════════════════════════════════════════╗
   ║                   上传工具更新选项                         ║
   ╠════════════════════════════════════════════════════════════╣
   ║  1) 保留现有上传工具(推荐,节省下载时间)                ║
   ║  2) 删除并重新下载(如果工具有更新)                      ║
   ╚════════════════════════════════════════════════════════════╝

选项1 - 保留现有工具:
- 创建临时目录备份dist/玩玩云上传工具.exe
- 更新upload-tool目录的脚本文件
- 恢复备份的可执行文件
- 优点: 节省1-2分钟下载时间,避免网络问题

选项2 - 重新下载:
- 删除整个upload-tool目录
- 在后续步骤重新下载最新工具
- 适用: 官方发布了新版本上传工具

默认行为:
- 默认选项1(保留),直接回车即可
- 如果现有文件大小异常(<30MB),自动重新下载
- 如果不存在上传工具,直接复制新目录

技术改动:
- install.sh update_pull_latest_code() 函数
- 添加用户交互选择逻辑
- 添加文件大小验证
- 添加备份和恢复逻辑

使用建议:
- 日常更新: 选择"1"保留,节省时间
- 重大版本更新: 选择"2"重新下载,确保最新

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-11-16 00:11:17 +08:00
2025-11-13 23:13:24 +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%