🎵 Songloft 快速使用指南

🎵 面向个人用户的自托管音乐服务器 — 仅管理你合法拥有的音乐
📣 关于改名:本项目自 v2.0 起由 MiMusic 更名为 Songloft(内核与功能不变,仅品牌升级)。老的
mimusic-orgGitHub 组织与hanxi/mimusicDocker 镜像保留至少一年作跳转,但不再更新。详见 GitHub Releases。
🏠 GitHub • 📥 下载 • 📖 文档 • 💬 问题反馈 • 👥 微信群 • 📸 截图
✨ 核心功能
- 🎵 本地音乐管理 — 扫描本地目录,自动提取 MP3/FLAC/WAV/APE/OGG/M4A 等格式的封面和元数据
- 🧩 JS 插件体系 — 基于 QuickJS 沙箱运行,支持权限模型、健康检查、热更新,可自由扩展音源 / 元数据 / 设备控制等能力
- 📱 跨平台客户端 — Flutter 客户端支持 Android、iOS、macOS、Windows、Linux、Web 六端
- 🌐 Web 界面 — 完整版内置 Web 前端,开箱即用
- 🔑 JWT 认证 — 双 Token 机制(Access Token + Refresh Token),支持多设备管理
- 📡 网络歌曲 & 电台 — 支持添加你已合法获取的网络音频 URL 与电台
- 🔁 歌单转本地 — 把你已合法持有的网络音频 URL 离线落盘到本地音乐库,按歌单分目录、可读文件名命名,转换后回写元数据 / 封面 / 歌词。⚠️ 仅限本人合法持有使用权的内容;下载未授权的版权资源属于侵权,由使用者自行承担责任
- 🔌 完整 REST API — 内置 Swagger 文档,方便集成和二次开发
- ⚡ 轻量高效 — Go 编写,CGO-free,无外部依赖,适合 NAS / 树莓派等低功耗设备
⚖️ 版权与免责声明
Songloft 是一款面向个人用户的自托管工具,定位为帮助用户管理自己合法拥有的音乐文件。在使用本项目前,请务必阅读并理解以下条款:
- 🚫 不提供任何音乐内容 — Songloft 本身不内置、不分发、不存储任何受版权保护的音乐资源,仅是一个供你管理本地音乐库的开源软件
- ✅ 请仅管理合法来源的音乐 — 用户应仅使用 Songloft 管理自己合法获得的音乐文件,包括但不限于:
- 自行购买并下载的数字音乐
- 从实体唱片转录的个人备份
- 自己创作或录制的作品
- 公有领域(Public Domain)作品
- 明确以 CC(Creative Commons)等开源协议授权的作品
- 🔌 第三方插件免责 — JS 插件由第三方社区维护,主仓库不预置、不分发任何第三方音源插件成品。插件接入的任何网络音源、元数据、歌词内容版权均归原权利人所有。使用网络音源、歌单转本地等功能下载或转存内容时,用户须自行承担版权合规责任,并遵守所在国家 / 地区的法律法规
- 🏠 仅供个人非商业使用 — 严禁将本项目用于商业用途、对外公开分发版权内容,或搭建面向不特定多数人的公共服务
- ⚠️ 责任自担 — 因不当使用本项目(包括但不限于侵犯第三方版权)所引发的任何法律责任、纠纷或损失,均由使用者本人承担,本项目作者及贡献者不承担任何责任
- ™️ 商标声明 — 本项目及内置插件中提到的所有品牌、协议、产品名称(包括但不限于「MIoT」「Bluetooth」「Android」「iOS」「macOS」「Windows」「Docker」等)均归各自商标权人所有。相关名称的出现仅出于互操作和指示性合理使用目的,Songloft 与上述商标持有人无任何关联,也未获得任何形式的授权或背书。详见 NOTICE
- 🔒 隐私 — Songloft 服务端不内置任何遥测,所有数据保存在你本地。详见 PRIVACY.md
💡 我们尊重并支持知识产权保护。如果你喜欢某位艺术家的作品,请通过正版渠道购买或订阅以支持创作者。
📋 版本说明
Songloft 提供两种版本,满足不同使用场景:
| 版本 | 后缀 | 说明 | 适用场景 |
|---|---|---|---|
| 🌟 完整版 | 无后缀 | 包含 Web 前端,开箱即用 | 推荐初次使用,访问服务地址即可看到 Web 界面 |
| 📦 精简版 | -lite | 不包含 Web 前端,体积更小 | 配合 Flutter 桌面/移动客户端,或前后端分离部署 |
💡 推荐:初次使用直接下载默认的 完整版,开箱即用,无需额外配置前端。
🖥️ 平台支持
📦 二进制文件
🌟 完整版(推荐)
包含 Web 前端,开箱即用:
| 平台 | 架构 | 下载链接 |
|---|---|---|
| 🐧 Linux | x86_64 | songloft-linux-amd64 |
| 🐧 Linux | ARM64 | songloft-linux-arm64 |
| 🐧 Linux | ARMv7 | songloft-linux-armv7 |
| 🍎 macOS | x86_64 (Intel) | songloft-darwin-amd64 |
| 🍎 macOS | ARM64 (Apple Silicon) | songloft-darwin-arm64 |
| 🪟 Windows | x86_64 | songloft-windows-amd64.exe |
| 🪟 Windows | ARM64 | songloft-windows-arm64.exe |
📦 精简版(Lite)
不包含 Web 前端,体积更小:
| 平台 | 架构 | 下载链接 |
|---|---|---|
| 🐧 Linux | x86_64 | songloft-linux-amd64-lite |
| 🐧 Linux | ARM64 | songloft-linux-arm64-lite |
| 🐧 Linux | ARMv7 | songloft-linux-armv7-lite |
| 🍎 macOS | x86_64 (Intel) | songloft-darwin-amd64-lite |
| 🍎 macOS | ARM64 (Apple Silicon) | songloft-darwin-arm64-lite |
| 🪟 Windows | x86_64 | songloft-windows-amd64-lite.exe |
| 🪟 Windows | ARM64 | songloft-windows-arm64-lite.exe |
🐳 Docker 镜像
🌟 完整版(推荐)
| 平台 | 下载链接 |
|---|---|
| 🐧 Linux x86_64 | songloft-docker-linux-amd64.tar |
| 🐧 Linux ARM64 | songloft-docker-linux-arm64.tar |
| 🐧 Linux ARMv7 | songloft-docker-linux-arm-v7.tar |
📦 精简版(Lite)
| 平台 | 下载链接 |
|---|---|
| 🐧 Linux x86_64 | songloft-docker-linux-amd64-lite.tar |
| 🐧 Linux ARM64 | songloft-docker-linux-arm64-lite.tar |
| 🐧 Linux ARMv7 | songloft-docker-linux-arm-v7-lite.tar |
📱 Flutter 客户端
除了 Web 界面,Songloft 还提供功能更强大的跨平台 Flutter 客户端,支持后台播放、本地缓存、媒体控制(耳机/锁屏/通知栏)等服务端 Web 界面无法实现的能力,覆盖 iOS、Android、macOS、Windows、Linux 和 Web 六端。
🔗 GitHub 仓库:songloft-org/songloft-player 📥 下载:GitHub Releases
💡 使用 精简版(-lite) 服务端时,推荐直接搭配 Flutter 客户端使用(无需额外部署 Web 前端);如确实需要独立 Web 前端,可参考 songloft-player 仓库的
flutter build web流程自行构建并由 Nginx 等反向代理静态托管。
🚀 快速开始
🔐 安全提示(必读):默认管理员账号是
admin / admin,仅适用于本地测试。任何对外网暴露或多设备访问的部署,请务必通过环境变量ADMIN_USERNAME/ADMIN_PASSWORD设置强密码后再启动;否则你的音乐库可能被陌生人访问。
📦 方式一:直接运行二进制文件
🐧 Linux / 🍎 macOS
# 1️⃣ 下载对应平台的二进制文件(默认即完整版)
# 例如 Linux x86_64:
wget https://github.com/songloft-org/songloft/releases/latest/download/songloft-linux-amd64
mv songloft-linux-amd64 songloft
# 2️⃣ 添加执行权限
chmod +x songloft
# 3️⃣ 创建必要目录
mkdir -p music data
# 4️⃣ 启动(推荐通过环境变量传入凭证,避免出现在 shell history / 进程列表中)
ADMIN_USERNAME=admin ADMIN_PASSWORD='your_strong_password' ./songloft🍎 macOS 用户注意:从 GitHub 下载的二进制带有 Gatekeeper 隔离属性,首次运行会被拦截。运行前请先执行:
bashxattr -d com.apple.quarantine ./songloft
🪟 Windows
# 1️⃣ 下载对应平台的二进制文件(默认即完整版),并重命名为 songloft.exe
# 例如 Windows x86_64: songloft-windows-amd64.exe
# 2️⃣ 创建必要目录
mkdir music
mkdir data
# 3️⃣ 设置环境变量并启动(PowerShell)
$env:ADMIN_USERNAME = "admin"
$env:ADMIN_PASSWORD = "your_strong_password"
.\songloft.exe🐳 方式二:Docker 部署
🌐 从 Docker Hub 拉取(推荐)
# 🌟 完整版(推荐,包含 Web 前端,:latest 即完整版)
docker pull songloft/songloft:latest
# 📦 精简版(不含 Web 前端,需搭配 Flutter 客户端使用)
docker pull songloft/songloft:lite
# 运行容器
docker run -d \
--name songloft \
-p 58091:58091 \
-v /path/to/music:/app/music \
-v /path/to/data:/app/data \
-e ADMIN_USERNAME=admin \
-e ADMIN_PASSWORD='your_strong_password' \
songloft/songloft:latest📥 从 Release 离线导入镜像
适合无法直接访问 Docker Hub 的环境:
# 1️⃣ 下载对应平台的 Docker 镜像 tar 文件(默认即完整版)
wget https://github.com/songloft-org/songloft/releases/latest/download/songloft-docker-linux-amd64.tar
# 2️⃣ 导入镜像
docker load -i songloft-docker-linux-amd64.tar
# 3️⃣ 查看导入的镜像标签
docker images | grep songloft
# 4️⃣ 使用上一节的 docker run 命令启动即可(注意替换为导入的镜像标签)🐙 Docker Compose 部署(推荐)
使用 Docker Compose 可以更方便地管理容器配置:
version: '3.8'
services:
songloft:
image: songloft/songloft:latest
container_name: songloft
restart: always
ports:
- "58091:58091"
volumes:
- /path/to/music:/app/music
- /path/to/data:/app/data
environment:
- ADMIN_USERNAME=admin
- ADMIN_PASSWORD=your_strong_password
- LISTEN_PORT=58091将上述内容保存为 docker-compose.yml 文件,然后运行:
# 启动服务
docker-compose up -d
# 查看日志
docker-compose logs -f
# 停止服务
docker-compose down📋 使用流程
1️⃣ 启动服务
服务启动后,访问 http://localhost:58091 即可打开 Web 界面(仅完整版内置;精简版请使用 Flutter 客户端 连接)。
2️⃣ 登录系统
使用配置的管理员账号密码登录。
3️⃣ 配置音乐目录
首次登录后,进入「设置」页面配置音乐文件目录(music_path)。Docker 部署时通常配置为 /app/music。
4️⃣ 扫描音乐
在 Web 界面中点击"扫描"按钮,系统会自动扫描音乐目录中的音频文件并提取元数据。
5️⃣ 播放音乐
扫描完成后,即可在界面中浏览和播放音乐。
⚙️ 配置说明
Songloft 仅依赖少量启动期配置(凭证、端口、数据库路径)通过环境变量或命令行参数指定,其余业务配置(音乐目录、扫描规则、封面存储等)都保存在数据库 config 表中,启动后通过 Web 界面管理。
🌍 环境变量
| 变量名 | 说明 | 默认值 |
|---|---|---|
ADMIN_USERNAME | 👤 管理员用户名 | admin |
ADMIN_PASSWORD | 🔐 管理员密码 | admin |
LISTEN_PORT | 🔌 服务端口 | 58091 |
DB_PATH | 💾 数据库文件路径 | data/songloft.db |
BASE_PATH | 🔗 URL 基础路径(反向代理子路径部署用,如 /songloft) | 空(根路径) |
📁 Docker 镜像中音乐目录与数据目录固定为
/app/music与/app/data,通过-v挂载即可,无需额外环境变量。
💻 命令行参数
# 查看帮助
./songloft -help
# 指定端口
./songloft -port 8080
# 指定数据库文件路径
./songloft -db data/songloft.db
# 指定管理员账号(不推荐,密码会出现在 shell history 和 ps 进程列表中)
./songloft -username admin -password your_password
# 指定子路径(反向代理部署时使用)
./songloft -base-path /songloft⚙️ 优先级:命令行参数 高于 环境变量。若两者均未提供,则回退到默认值(管理员账号为
admin/admin)。 ⚠️ 参数格式:Songloft 使用单横杠参数(如-help),不支持双横杠参数(如--help)。 🔐 密码安全:推荐通过环境变量ADMIN_PASSWORD传入密码,避免-password在进程列表中明文暴露。
🌐 反向代理子路径部署
如果你通过 Nginx 等反向代理将 Songloft 挂在子路径下(如 https://nas.example.com/songloft/),需要配置 BASE_PATH 环境变量。
配置步骤
1. 启动 Songloft 时指定 BASE_PATH:
# 环境变量方式
BASE_PATH=/songloft ./songloft
# 或命令行参数方式
./songloft -base-path /songloft
# Docker 方式
docker run -d \
--name songloft \
-p 58091:58091 \
-v /path/to/music:/app/music \
-v /path/to/data:/app/data \
-e ADMIN_USERNAME=admin \
-e ADMIN_PASSWORD='your_strong_password' \
-e BASE_PATH=/songloft \
songloft/songloft:latest2. 配置 Nginx 反向代理:
location /songloft/ {
proxy_pass http://127.0.0.1:58091;
proxy_read_timeout 52w;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}⚠️ 注意:
proxy_pass末尾不要加斜杠。Nginx 会将完整路径(含/songloft/)转发给后端,由 Songloft 自行处理前缀剥离。
客户端连接
| 客户端类型 | 服务器地址填写 |
|---|---|
| 内置 Web 前端 | 浏览器直接访问 https://nas.example.com/songloft/,自动工作 |
| Flutter 桌面/移动客户端 | 填写 https://nas.example.com/songloft |
Docker Compose 示例
version: '3.8'
services:
songloft:
image: songloft/songloft:latest
container_name: songloft
restart: always
ports:
- "58091:58091"
volumes:
- /path/to/music:/app/music
- /path/to/data:/app/data
environment:
- ADMIN_USERNAME=admin
- ADMIN_PASSWORD=your_strong_password
- BASE_PATH=/songloft💻 系统要求
| 项目 | 要求 |
|---|---|
| 操作系统 | 🐧 Linux / 🍎 macOS / 🪟 Windows |
| 架构 | x86_64 / ARM64 / ARMv7 |
| 可选依赖 | 🔧 ffprobe(用于获取音频技术参数,不安装也可正常运行) |
✅ 校验文件完整性
每个 Release 都包含 checksums.txt 文件,用于验证下载文件的完整性:
# 下载校验和文件
wget https://github.com/songloft-org/songloft/releases/latest/download/checksums.txt
# 验证文件
sha256sum -c checksums.txt📌 版本检查
# 查看版本信息(含 Git Commit / 构建时间 / 构建类型)
./songloft -version
# 查看完整帮助
./songloft -help
# 通过 API 检查版本
curl http://localhost:58091/api/v1/version输出示例:
Songloft Version: x.y.z
Git Commit: abc1234
Build Time: 2026-01-01_00:00:00
Build Type: full🔌 插件系统
Songloft 内置 JS 插件引擎,插件运行在 QuickJS 沙箱中,支持权限模型、健康检查与热更新,可自由扩展音源 / 元数据 / 设备控制等能力。
🎯 插件获取
每个插件在自己的 GitHub 仓库下分发:进到对应仓库的 Releases 页下载最新版的 .jsplugin.zip,再到 Songloft 客户端的「插件管理」页上传即可启用。可在 插件合集 Issue 找到当前可用的插件清单。
想看更多插件或共建?欢迎在 插件合集 Issue 留言。
⚠️ 版权提示:第三方插件接入的任何网络音源、歌词、封面等内容,版权均归原权利人所有。请仅将插件用于访问你本人享有合法使用权的内容,下载 / 转存 / 二次分发等行为请遵守所在国家或地区的法律法规。详见上文 版权与免责声明。
🛠️ 插件开发
如需开发自定义插件,请参考以下资源:
- 开发工具链: songloft-org/plugin-toolchain —
@songloft/plugin-sdk+@songloft/plugin-builder+ 脚手架 - 快速开始:
pnpm create songloft-plugin <name>,详见 JS 插件开发指南
📖 API 文档
完整的 API 文档(Swagger/OpenAPI 格式)可在以下地址查看:
- Swagger API 文档: swagger.json
- Swagger UI 在线查看: petstore.swagger.io
- 本地查看: 启动服务后访问
http://localhost:58091/swagger/index.html
主要接口概览
| 接口组 | 路径 | 说明 |
|---|---|---|
| 认证 | /api/v1/auth/* | 登录、刷新 Token、登出、Token 管理 |
| 歌曲 | /api/v1/songs/* | 歌曲 CRUD、封面、播放、歌词 |
| 歌单 | /api/v1/playlists/* | 歌单 CRUD、歌单歌曲管理、网络歌曲转本地 |
| JS 插件 | /api/v1/jsplugins/* | 插件上传、启用、禁用、删除、检查更新 |
| 扫描 | /api/v1/scan/* | 音乐库扫描 |
| 配置 | /api/v1/configs/* | 系统配置管理 |
| 版本 | /api/v1/version | 版本信息 |
❓ 常见问题
遇到问题?请查看 常见问题与解决方案 💬
🛠️ 技术支持
- GitHub: songloft-org/songloft
- Issues: 问题与反馈
- 💬 加入微信群交流:微信群二维码
- 🐧 QQ群: 979995241
📝 更新日志
详细的版本更新记录请查看 CHANGELOG.md。
📄 许可证
本项目基于 Apache-2.0 License 开源。
