# 文件上传系统文档 ## 概述 文件上传系统为解班客平台提供了完整的文件管理功能,支持多种文件类型的上传、处理、存储和管理。系统采用模块化设计,支持图片处理、文件验证、安全控制等功能。 ## 系统架构 ### 核心组件 1. **上传中间件** (`middleware/upload.js`) - 文件上传处理 - 文件类型验证 - 大小限制控制 - 存储路径管理 2. **图片处理器** - 图片压缩和格式转换 - 缩略图生成 - 尺寸调整 - 质量优化 3. **文件管理控制器** (`controllers/admin/fileManagement.js`) - 文件列表管理 - 文件统计分析 - 批量操作 - 清理功能 4. **错误处理机制** - 统一错误响应 - 详细错误日志 - 安全错误信息 ## 支持的文件类型 ### 图片文件 - **格式**: JPG, JPEG, PNG, GIF, WebP - **用途**: 头像、动物图片、旅行照片 - **处理**: 自动压缩、生成缩略图、格式转换 ### 文档文件 - **格式**: PDF, DOC, DOCX, XLS, XLSX, TXT - **用途**: 证书、合同、报告等 - **处理**: 文件验证、病毒扫描(计划中) ## 文件分类存储 ### 存储目录结构 ``` uploads/ ├── avatars/ # 用户头像 ├── animals/ # 动物图片 ├── travels/ # 旅行图片 ├── documents/ # 文档文件 └── temp/ # 临时文件 ``` ### 文件命名规则 - **格式**: `{timestamp}_{randomString}.{extension}` - **示例**: `1701234567890_a1b2c3d4.jpg` - **优势**: 避免重名、便于排序、安全性高 ## 上传限制配置 ### 头像上传 - **文件类型**: JPG, PNG - **文件大小**: 最大 2MB - **文件数量**: 1个 - **处理**: 300x300像素,生成100x100缩略图 ### 动物图片上传 - **文件类型**: JPG, PNG, GIF, WebP - **文件大小**: 最大 5MB - **文件数量**: 最多 5张 - **处理**: 800x600像素,生成200x200缩略图 ### 旅行图片上传 - **文件类型**: JPG, PNG, GIF, WebP - **文件大小**: 最大 5MB - **文件数量**: 最多 10张 - **处理**: 1200x800像素,生成300x300缩略图 ### 文档上传 - **文件类型**: PDF, DOC, DOCX, XLS, XLSX, TXT - **文件大小**: 最大 10MB - **文件数量**: 最多 3个 - **处理**: 仅验证,不做格式转换 ## API接口说明 ### 文件上传接口 #### 1. 头像上传 ```http POST /api/v1/admin/files/upload/avatar Content-Type: multipart/form-data avatar: [文件] ``` #### 2. 动物图片上传 ```http POST /api/v1/admin/files/upload/animal Content-Type: multipart/form-data images: [文件1, 文件2, ...] ``` #### 3. 旅行图片上传 ```http POST /api/v1/admin/files/upload/travel Content-Type: multipart/form-data images: [文件1, 文件2, ...] ``` #### 4. 文档上传 ```http POST /api/v1/admin/files/upload/document Content-Type: multipart/form-data documents: [文件1, 文件2, ...] ``` ### 文件管理接口 #### 1. 获取文件列表 ```http GET /api/v1/admin/files?page=1&limit=20&type=all&keyword=搜索词 ``` #### 2. 获取文件详情 ```http GET /api/v1/admin/files/{file_id} ``` #### 3. 删除文件 ```http DELETE /api/v1/admin/files/{file_id} ``` #### 4. 批量删除文件 ```http POST /api/v1/admin/files/batch/delete Content-Type: application/json { "file_ids": ["id1", "id2", "id3"] } ``` #### 5. 获取文件统计 ```http GET /api/v1/admin/files/statistics ``` #### 6. 清理无用文件 ```http POST /api/v1/admin/files/cleanup?dry_run=true ``` ## 图片处理功能 ### 自动处理流程 1. **上传验证**: 检查文件类型、大小、数量 2. **格式转换**: 统一转换为JPEG格式(可配置) 3. **尺寸调整**: 按预设尺寸调整图片大小 4. **质量压缩**: 优化文件大小,保持视觉质量 5. **缩略图生成**: 生成小尺寸预览图 6. **文件保存**: 保存到指定目录 ### 处理参数配置 ```javascript // 头像处理配置 { width: 300, height: 300, quality: 85, format: 'jpeg', thumbnail: true, thumbnailSize: 100 } // 动物图片处理配置 { width: 800, height: 600, quality: 80, format: 'jpeg', thumbnail: true, thumbnailSize: 200 } ``` ## 安全机制 ### 文件验证 1. **MIME类型检查**: 验证文件真实类型 2. **文件扩展名检查**: 防止恶意文件上传 3. **文件大小限制**: 防止大文件攻击 4. **文件数量限制**: 防止批量上传攻击 ### 存储安全 1. **随机文件名**: 防止文件名猜测 2. **目录隔离**: 不同类型文件分目录存储 3. **访问控制**: 通过Web服务器配置访问权限 4. **定期清理**: 自动清理临时和无用文件 ### 错误处理 1. **统一错误格式**: 标准化错误响应 2. **详细日志记录**: 记录所有操作和错误 3. **安全错误信息**: 不暴露系统内部信息 4. **异常恢复**: 上传失败时自动清理临时文件 ## 性能优化 ### 图片优化 1. **智能压缩**: 根据图片内容调整压缩参数 2. **格式选择**: 自动选择最优图片格式 3. **渐进式JPEG**: 支持渐进式加载 4. **WebP支持**: 现代浏览器使用WebP格式 ### 存储优化 1. **分目录存储**: 避免单目录文件过多 2. **CDN集成**: 支持CDN加速(计划中) 3. **缓存策略**: 合理设置HTTP缓存头 4. **压缩传输**: 启用gzip压缩 ### 并发处理 1. **异步处理**: 图片处理使用异步操作 2. **队列机制**: 大批量操作使用队列(计划中) 3. **限流控制**: 防止并发上传过多 4. **资源监控**: 监控CPU和内存使用 ## 监控和统计 ### 文件统计 - **总文件数量**: 系统中所有文件的数量 - **存储空间使用**: 各类型文件占用的存储空间 - **文件格式分布**: 不同格式文件的数量和占比 - **上传趋势**: 文件上传的时间趋势 ### 性能监控 - **上传成功率**: 文件上传的成功率统计 - **处理时间**: 文件处理的平均时间 - **错误率**: 各类错误的发生频率 - **存储使用率**: 存储空间的使用情况 ### 日志记录 - **操作日志**: 记录所有文件操作 - **错误日志**: 记录所有错误和异常 - **性能日志**: 记录性能相关数据 - **安全日志**: 记录安全相关事件 ## 维护和管理 ### 定期维护任务 1. **清理临时文件**: 每小时清理超过24小时的临时文件 2. **清理无用文件**: 定期扫描和清理不再使用的文件 3. **日志轮转**: 定期归档和清理日志文件 4. **存储空间监控**: 监控存储空间使用情况 ### 备份策略 1. **增量备份**: 每日增量备份新上传的文件 2. **全量备份**: 每周全量备份所有文件 3. **异地备份**: 重要文件异地备份(计划中) 4. **恢复测试**: 定期测试备份恢复功能 ### 故障处理 1. **自动恢复**: 临时故障自动重试 2. **降级服务**: 服务异常时提供基础功能 3. **故障通知**: 严重故障及时通知管理员 4. **快速恢复**: 提供快速故障恢复方案 ## 使用示例 ### 前端上传示例 #### HTML表单上传 ```html
``` #### JavaScript上传 ```javascript async function uploadFiles(files, type = 'animal') { const formData = new FormData(); // 添加文件到表单数据 for (let i = 0; i < files.length; i++) { formData.append('images', files[i]); } try { const response = await fetch(`/api/v1/admin/files/upload/${type}`, { method: 'POST', headers: { 'Authorization': `Bearer ${token}` }, body: formData }); const result = await response.json(); if (result.success) { console.log('上传成功:', result.data.files); return result.data.files; } else { throw new Error(result.message); } } catch (error) { console.error('上传失败:', error); throw error; } } // 使用示例 const fileInput = document.getElementById('fileInput'); fileInput.addEventListener('change', async (e) => { const files = e.target.files; if (files.length > 0) { try { const uploadedFiles = await uploadFiles(files, 'animal'); // 处理上传成功的文件 displayUploadedFiles(uploadedFiles); } catch (error) { // 处理上传错误 showError(error.message); } } }); ``` #### Vue.js组件示例 ```vue或拖拽文件到此处
上传中... {{ progress }}%
{{ file.originalName }}
{{ formatFileSize(file.size) }}