news 2026/4/18 9:09:58

轻量级云文件系统simple-file-server,电脑秒变存储服务器

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
轻量级云文件系统simple-file-server,电脑秒变存储服务器

Simple File Server

一个简单的文件服务器,使用 Go 和 Gin 框架构建,支持文件上传、下载和静态文件服务。

功能特性

  • 文件上传:支持普通文件上传和分片上传(multipart upload)

  • 文件下载:通过 HTTP GET 请求下载文件

  • 静态文件服务:自动服务数据目录中的文件

  • API 认证:上传操作需要 admin-api-token 认证

  • 跨平台支持:支持 Linux 和 macOS 的 amd64 和 arm64 架构

安装

从源码构建

确保你已经安装了 Go 1.22 或更高版本。

git clone <repository-url>cd simple-file-server make

构建完成后,二进制文件将在build/目录中生成。

使用 Docker 构建

确保你已经安装了 Docker。

docker build -t simple-file-server . docker run -p 60088:60088 --rm \ -v $(pwd)/data-docker:/data:rw \ -v $(pwd)/config.json:/config.json simple-file-server

下载预编译二进制文件

从 release 页面下载适合你平台的二进制文件。

配置

服务器通过config.json文件进行配置:

{ "debug": false, "port": 60088, "apiToken": "your-admin-api-token", "tempDir": "./temp", "dataDir": "./data"}
  • debug: 是否启用调试模式

  • port: 服务器监听端口

  • apiToken: 管理员 API 令牌,用于上传操作

  • tempDir: 临时文件目录

  • dataDir: 数据文件存储目录

运行

使用二进制文件

./simple-file-server

使用 Docker

docker run -p 60088:60088 -v $(pwd)/data:/root/data -v $(pwd)/temp:/root/temp simple-file-server

服务器将在配置的端口上启动,并开始监听请求。

API 文档

Ping

检查服务器状态。

  • URL:/_admin/ping

  • Method: GET

  • Response:{"code": 0, "msg": "ok", "data": "ok"}

文件上传

上传单个文件。

  • URL:/_admin/upload

  • Method: POST

  • Headers:

    • admin-api-token: 管理员令牌

  • Form Data:

    • file: 要上传的文件

    • filePath: 文件保存路径(必需)

  • Response:{"code": 0, "msg": "ok", "data": {"filePath": "path/to/file"}}

分片上传初始化

初始化分片上传。

  • URL:/_admin/upload/multipart_init

  • Method: POST

  • Headers:

    • admin-api-token: 管理员令牌

    • Content-Type: application/json

  • Body:

    { "filePath": "example.txt", "totalParts": 10, "totalSize": 10485760}
  • Response:{"code": 0, "msg": "ok", "data": {"uploadId": "123456789"}}

分片上传

上传文件的一个分片。

  • URL:/_admin/upload/multipart_upload

  • Method: POST

  • Headers:

    • admin-api-token: 管理员令牌

  • Form Data:

    • uploadId: 上传 ID

    • partNumber: 分片编号

    • file: 分片文件

  • Response:{"code": 0, "msg": "ok", "data": "ok"}

分片上传完成

完成分片上传并合并文件。

  • URL:/_admin/upload/multipart_end

  • Method: POST

  • Headers:

    • admin-api-token: 管理员令牌

    • Content-Type: application/json

  • Body:

    { "uploadId": "123456789"}
  • Response:{"code": 0, "msg": "ok", "data": {"filePath": "example.txt"}}

分片上传中止

中止分片上传并清理临时文件。

  • URL:/_admin/upload/abort

  • Method: POST

  • Headers:

    • admin-api-token: 管理员令牌

    • Content-Type: application/json

  • Body:

    { "uploadId": "123456789"}
  • Response:{"code": 0, "msg": "ok", "data": "ok"}

检查文件是否存在

检查指定文件是否存在。

  • URL:/_admin/has

  • Method: POST

  • Headers:

    • admin-api-token: 管理员令牌

    • Content-Type: application/json

  • Body:

    { "path": "path/to/file.txt"}
  • Response:{"code": 0, "msg": "ok", "data": true}{"code": 0, "msg": "ok", "data": false}

获取文件大小

获取指定文件的大小。

  • URL:/_admin/size

  • Method: POST

  • Headers:

    • admin-api-token: 管理员令牌

    • Content-Type: application/json

  • Body:

    { "path": "path/to/file.txt"}
  • Response:{"code": 0, "msg": "ok", "data": {"size": 12345}}(文件大小字节数)

获取文件内容

获取指定文件的内容。

  • URL:/_admin/get

  • Method: POST

  • Headers:

    • admin-api-token: 管理员令牌

    • Content-Type: application/json

  • Body:

    { "path": "path/to/file.txt"}
  • Response:二进制数据

移动文件

移动文件到新位置。

  • URL:/_admin/move

  • Method: POST

  • Headers:

    • admin-api-token: 管理员令牌

    • Content-Type: application/json

  • Body:

    { "from": "old/path/file.txt", "to": "new/path/file.txt"}
  • Response:{"code": 0, "msg": "ok", "data": "ok"}

删除文件

删除指定文件。

  • URL:/_admin/delete

  • Method: POST

  • Headers:

    • admin-api-token: 管理员令牌

    • Content-Type: application/json

  • Body:

    { "path": "path/to/file.txt"}
  • Response:{"code": 0, "msg": "ok", "data": "ok"}

文件下载

下载文件。

  • URL:/{fileName}

  • Method: GET

  • Response: 文件内容

许可证

Apache 2.0 License

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/12 22:18:51

百考通AI让学术启航从“无从下手”到“一气呵成”

对于每一位即将踏上学术研究征程的学子而言&#xff0c;开题报告是迈入正式研究阶段的第一道也是至关重要的门槛。它不仅是对研究课题的初步规划和论证&#xff0c;更是向导师和评审委员会展示你研究能力与潜力的“敲门砖”。然而&#xff0c;面对空白的文档、模糊的研究方向和…

作者头像 李华
网站建设 2026/4/17 18:45:35

百考通AI任务书功能:智能生成贴合你研究方向的专业任务书,规范高效一步到位

毕业设计任务书是高校教学流程中承前启后的关键环节——它不仅是选题的正式确认&#xff0c;更是后续研究、开发与论文撰写的行动纲领。然而&#xff0c;许多学生在撰写时常常陷入“有想法却写不出”“懂技术但不会表达”“找模板又不匹配”的困境&#xff0c;导致内容空泛、结…

作者头像 李华
网站建设 2026/4/6 12:18:39

Chrome 自动填充“用户名”到普通输入框 - 解决方案

Chrome 自动填充“用户名”到普通输入框&#xff1f;我被 Seller ID 坑了一天 简介 在后台系统或业务表单中&#xff0c;我们经常会遇到一些完全不是登录账号的字段&#xff0c;却被 Chrome 强行自动填充为浏览器保存的用户名或邮箱。 本文将以 Seller ID 输入框被 Chrome 自动…

作者头像 李华
网站建设 2026/4/18 8:20:41

效率革命----Browser-Use 与 Cline:昨天,AI 终于学会了“自己操作电脑” [特殊字符]️

摘要:你是否想过,AI 不应该只在对话框里陪你聊天,而应该帮你去买票、填表、修 Bug?昨天 GitHub 上最火的两个 Agent 项目——Browser-Use(让 AI 控制浏览器)和 Cline(让 AI 控制 VS Code),正在把“全自动工作流”变成现实。本文手把手教你配置这两个神器,解放双手。 …

作者头像 李华
网站建设 2026/4/11 19:20:34

救命神器!专科生必用8款AI论文工具测评TOP8

救命神器&#xff01;专科生必用8款AI论文工具测评TOP8 为什么专科生需要这份AI论文工具测评&#xff1f; 随着人工智能技术的不断进步&#xff0c;越来越多的专科生开始借助AI工具提升论文写作效率。然而&#xff0c;面对市场上五花八门的AI论文辅助软件&#xff0c;如何选择真…

作者头像 李华