当前位置: 首页 > news >正文

轻量级云文件系统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

http://www.jsqmd.com/news/259055/

相关文章:

  • JBoltAI的AI应用中台:构建企业智能化的坚实基础
  • 企业上云转型的 “压舱石”—— 云服务器如何破解中小微企业数字化痛点​
  • 基于逻辑回归模型的贷款违约预测(设计源文件+万字报告+讲解)(支持资料、图片参考_相关定制)_文章底部可以扫码
  • 一键生成专业文献综述
  • 数字经济的 “安全基石”—— 云服务器零信任架构如何筑牢数据安全防线​
  • 基于多模型比较的慢性肾病分类模型设计与优化研究(设计源文件+万字报告+讲解)(支持资料、图片参考_相关定制)_文章底部可以扫码
  • 鸿蒙6访问内网域名异常排查
  • 2026.1.17HCSA第二次作业
  • 2026必备!本科生毕业论文AI论文网站TOP9测评
  • Node.js用crypto.createCipheriv流式加密优化
  • 猫狗识别人工智能代码基于深度学习的猫狗识别系统完整源码+数据集+项目报告(设计源文件+万字报告+讲解)(支持资料、图片参考_相关定制)_文章底部可以扫码
  • 基于深度学习的车辆检测系统(设计源文件+万字报告+讲解)(支持资料、图片参考_相关定制)_文章底部可以扫码
  • AI 大模型时代的 “算力引擎”—— 云服务器如何支撑智能应用规模化落地​
  • 基于YOLOv5的葡萄叶片病虫害识别(设计源文件+万字报告+讲解)(支持资料、图片参考_相关定制)_文章底部可以扫码
  • 双碳目标下的 “绿色算力”—— 云服务器如何实现节能与性能双赢​
  • 百考通AI让复杂数据从“沉默的数字”到“决策的金矿”
  • 基于python机器学习的二手房数据分析(设计源文件+万字报告+讲解)(支持资料、图片参考_相关定制)_文章底部可以扫码
  • 基于Hadoop的电商推荐系统有报告(设计源文件+万字报告+讲解)(支持资料、图片参考_相关定制)_文章底部可以扫码
  • 百考通AI任务书功能:精准理解你的课题,智能输出专业级毕业设计任务书
  • 百考通AI任务书功能:智能生成结构完整、内容规范的毕业设计任务书
  • 基于python的电商订单数据可视化分析预测研究项目(设计源文件+万字报告+讲解)(支持资料、图片参考_相关定制)_文章底部可以扫码
  • 下载 | Win11 25H2 正式版1月更新!(系统ISO映像、年度更新版本、26200.7623、Windows 11)
  • 百考通AI让毕业论文写作化繁为简
  • 下载 | Win11 24H2 正式版更新!(系统ISO映像、多合一版本、26100.7623、Windows 11)
  • 百考通AI任务书功能:精准匹配专业要求,一键生成高质量毕业设计任务书
  • 惠州
  • 不用换显卡!大模型微调显存优化实操指南(附代码+效果对比)
  • 2026年雨棚/体育看台/景观/停车场/加油站膜结构加工厂家实力推荐:河南景天膜结构工程有限公司,十大场景定制解决方案 - 品牌推荐官
  • 基于深度学习 UNet 模型城市卫星遥感图像语义分割系统(参考示例)
  • 告别查重焦虑,重塑学术尊严