# 015 015 (/ˈzɪərəʊ wʌn faɪv/, "zero-one-five") 是一个支持selfhosted的临时文件分享平台。专注于提供一次性,临时的文件和文本上传,处理,分享服务。项目名称来源于DARLING in the FRANXX的 [莓](https://darling-in-the-franxx.fandom.com/wiki/Ichigo) 一个基于 Vue 3 + Nuxt 3 + Go 构建的现代文件分享网站,支持文件上传、文本分享、图片压缩、并发处理、秒传功能等,具备完整的分享管理和访问控制体系。 ![015 Platform Overview](/.github/image/0.png) [English](README.md) | 中文
## 🌟 功能特性 ### 核心功能 🖼️ **高性能文件上传** - 支持大文件切片上传,前端计算文件哈希实现秒传 📱 **响应式设计** - 基于 Tailwind V4 + Reka UI 的现代化 UI,适配各种设备 ⚡ **并发处理** - 使用 Web Worker 进行前端Hash计算,后端队列系统处理任务 🌐 **多语言支持** - 完整的中英文国际化支持 🔗 **分享管理** - 灵活的分享链接生成和管理系统 ### 文件处理 🔄 **智能秒传** - 基于文件哈希+文件大小的前端秒传检测,避免重复上传 📷 **图片压缩** - 自动图片压缩功能,支持多种格式 🖼️ **文件预览** - 支持图片、视频、音频、文档等多种文件类型预览 📊 **上传统计** - 实时显示上传进度和文件信息 🌈 **断点续传** - 支持上传中断后的续传功能 ### 高级功能 🎛️ **分享控制** - 支持密码保护、下载次数限制、过期时间设置 🔍 **取件码系统** - 支持取件码分享,简化分享难度 ⚡ **队列处理** - 基于 Redis + Asynq 的异步任务处理系统 🗂️ **文件管理** - 完整的文件生命周期管理 📷 **图片处理** - 图片压缩、格式转换等处理功能 🏷️ **下载控制** - 基于 JWT 的下载令牌管理系统 ## 📸 截图预览 | 选择文件上传页面 | 输入文本上传页面 | | ------------------------- | ------------------------- | | ![](/.github/image/1.png) | ![](/.github/image/2.png) | | 多选文件上传 | 文件上传进度热力图 | | ------------------------- | ------------------------- | | ![](/.github/image/3.png) | ![](/.github/image/4.png) | | 文件上传进度条 | 文件上传成功页面 | | ------------------------- | ------------------------- | | ![](/.github/image/5.png) | ![](/.github/image/6.png) | ## 🚀 快速开始 ### Docker 1. 下载文件 - config.example.yaml - docker-compose.yml 2. 把 config.example.yaml 配置完成后改为 config.yaml 3. 启动 ```bash docker compose up -d ``` 4. 访问 `http://localhost:8080` ## 🏗️ 技术架构 ### 前端技术栈 - **Vue 3** - 渐进式 JavaScript 框架 - **Nuxt 3** - Vue.js 全栈框架 - **TypeScript** - 完整的类型安全 - **Tailwind CSS** - 原子化 CSS 框架 - **Reka UI** - 现代化组件库 - **Pinia** - 状态管理 - **TanStack Query** - 数据获取和缓存 - **Vue Router** - 路由管理 - **i18next** - 国际化支持 ### 后端技术栈 - **Go 1.23** - 高性能服务器端语言 - **Echo** - 高性能 HTTP 框架 - **Redis** - 缓存和会话存储 - **Asynq** - 异步任务队列 - **JWT** - 身份验证 - **Zap** - 结构化日志 ### 构建系统 - **Node.js** - 服务器端运行时 - **pnpm** - 快速包管理器 - **Husky** - Git hooks 管理 - **Prettier** - 代码格式化 - **Lint-staged** - 暂存文件检查 ### 存储架构 - **文件存储** - 本地文件系统存储 - **Redis 缓存** - 分享信息、文件元数据缓存 - **队列系统** - 异步任务处理队列 ## 📁 项目结构 ``` 015/ ├── front/ # 前端应用 (Vue 3 + Nuxt 3) │ ├── components/ # Vue 组件 │ ├── pages/ # 页面路由 │ ├── composables/ # 组合式函数 │ ├── i18n/ # 国际化文件 │ ├── assets/ # 静态资源 │ ├── plugins/ # Nuxt 插件 │ └── server/ # 服务端路由 ├── backend/ # 后端服务 (Go + Echo) │ ├── internal/ # 内部包 │ │ ├── controllers/ # 控制器 │ │ ├── services/ # 业务逻辑 │ │ └── utils/ # 工具函数 │ └── middleware/ # 中间件 ├── worker/ # 异步任务处理 (Go + Asynq) │ ├── internal/ # 内部包 │ │ ├── tasks/ # 任务处理器 │ │ └── utils/ # 工具函数 │ └── middleware/ # 中间件 └── pkg/ # 公共包 ``` ## 🔧 开发指南 ### 代码规范 - 使用 Prettier 进行代码格式化 - 使用 Husky + lint-staged 进行提交前检查 - 遵循 TypeScript 类型安全规范 ### 提交规范 ```bash # 提交前会自动运行代码格式化 git add . git commit -m "feat: add new feature" ``` ### 构建部署 ```bash # 构建前端 cd front && pnpm run build # 构建后端 (需要 Go 环境) cd backend && go build -o main . # 构建 Worker cd worker && go build -o worker . ``` ## 📝 开发计划 ### 已完成功能 ✅ - 前端计算哈希和秒传 - 并发切片上传 (使用 Web Worker) - 文件上传/文本上传和分享 - 支持多文件上传 - 上传统计页面 - 多语言支持 - 最大上传限制 - 后端队列系统和 Worker 处理文件 - 断点续传 (后端计算已上传部分并返回) - 图片格式转换和压缩 ### 计划功能 🚧 - 图片 OCR 复制 - 文档转 Markdown - 文本翻译/总结 ## 🤝 贡献指南 欢迎提交 Issue 和 Pull Request 来改进这个项目。 ## 📄 许可证 本项目采用 AGPLV3 许可证。 ## 🔗 相关链接 - [Vue 3 文档](https://vuejs.org/) - [Nuxt 3 文档](https://nuxt.com/) - [Echo 框架文档](https://echo.labstack.com/) - [Asynq 文档](https://github.com/hibiken/asynq)