feishin

feishin

跨平台开源音乐播放器 支持Navidrome和Jellyfin服务器

Feishin是一款开源音乐播放器,支持Navidrome和Jellyfin服务器。它具有现代UI界面、MPV和Web播放器后端、智能播放列表编辑和歌词同步等功能。Feishin提供桌面客户端、Web版本和Docker部署方式,适用于本地音乐库和在线流媒体。该播放器支持跨平台使用,为音乐爱好者提供多样化的聆听选择。

Feishin音乐播放器开源软件多平台支持音乐服务器Github开源项目
<img src="https://yellow-cdn.veclightyear.com/835a84d5/80fd7fd2-052d-409b-bf9d-2c4168112e50.png" alt="标志" title="feishin" align="right" height="60px" />

Feishin

<p align="center"> <a href="https://github.com/jeffvli/feishin/blob/main/LICENSE"> <img src="https://img.shields.io/github/license/jeffvli/feishin?style=flat-square&color=brightgreen" alt="许可证"> </a> <a href="https://github.com/jeffvli/feishin/releases"> <img src="https://img.shields.io/github/v/release/jeffvli/feishin?style=flat-square&color=blue" alt="发布"> </a> <a href="https://github.com/jeffvli/feishin/releases"> <img src="https://img.shields.io/github/downloads/jeffvli/feishin/total?style=flat-square&color=orange" alt="下载量"> </a> </p> <p align="center"> <a href="https://discord.gg/FVKpcMDy5f"> <img src="https://img.shields.io/discord/922656312888811530?color=black&label=discord&logo=discord&logoColor=white" alt="Discord"> </a> <a href="https://matrix.to/#/#sonixd:matrix.org"> <img src="https://img.shields.io/matrix/sonixd:matrix.org?color=black&label=matrix&logo=matrix&logoColor=white" alt="Matrix"> </a> </p>

Sonixd的重写版本。

特性

  • MPV播放器后端
  • 网页播放器后端
  • 现代化界面
  • 将播放记录同步到您的服务器
  • 智能播放列表编辑器(Navidrome)
  • 支持同步和非同步歌词
  • 提出功能请求查看任务面板

截图

<a href="https://yellow-cdn.veclightyear.com/835a84d5/61df1da7-f1b0-47cf-a8ac-b3c7df765a76.png"><img src="https://yellow-cdn.veclightyear.com/835a84d5/61df1da7-f1b0-47cf-a8ac-b3c7df765a76.png" width="49.5%"/></a> <a href="https://yellow-cdn.veclightyear.com/835a84d5/302403b7-746d-4364-a99b-d589dd28674d.png"><img src="https://yellow-cdn.veclightyear.com/835a84d5/302403b7-746d-4364-a99b-d589dd28674d.png" width="49.5%"/></a> <a href="https://yellow-cdn.veclightyear.com/835a84d5/458f4874-ab2b-464c-bc8c-63550fa7d5b1.png"><img src="https://yellow-cdn.veclightyear.com/835a84d5/458f4874-ab2b-464c-bc8c-63550fa7d5b1.png" width="49.5%"/></a> <a href="https://yellow-cdn.veclightyear.com/835a84d5/fe3db514-d0ca-415c-85d1-dc3cab82da42.png"><img src="https://yellow-cdn.veclightyear.com/835a84d5/fe3db514-d0ca-415c-85d1-dc3cab82da42.png" width="49.5%"/></a>

入门指南

桌面版(推荐)

下载最新的桌面客户端。桌面客户端是使用Feishin的推荐方式。它同时支持MPV和网页播放器后端,并内置歌词获取功能。

MacOS注意事项

如果您使用的设备运行macOS 12(Monterey)或更高版本,请查看此处了解如何从隔离区移除应用程序的说明。

要使媒体键正常工作,系统会提示您允许Feishin成为受信任的辅助功能客户端。允许后,您需要重启Feishin以使隐私设置生效。

网页版和Docker

访问https://feishin.vercel.app使用Feishin的托管网页版。网页客户端仅支持网页播放器后端。 Feishin 也可以作为 Docker 镜像使用。镜像托管在 ghcr.io 上,可以在这里查看。您可以使用以下命令运行容器:

# 运行最新版本 docker run --name feishin -p 9180:9180 ghcr.io/jeffvli/feishin:latest # 在本地构建镜像 docker build -t feishin . docker run --name feishin -p 9180:9180 feishin

Docker Compose

要通过 Docker Compose 安装,请使用以下代码片段。这也适用于 Portainer。

version: '3'
services:
  feishin:
    container_name: feishin
    image: 'ghcr.io/jeffvli/feishin:latest'
    environment:
      - SERVER_NAME=jellyfin # 预定义服务器名称
      - SERVER_LOCK=true # 当设为 true 且名称/类型/URL 已设置时,只能切换用户名/密码
      - SERVER_TYPE=jellyfin # navidrome 也可以
      - SERVER_URL= # http://地址:端口
      - PUID=1000
      - PGID=1000
      - UMASK=002
      - TZ=America/Los_Angeles
    ports:
      - 9180:9180
    restart: unless-stopped

配置

  1. 启动时,您将看到提示选择 MPV 二进制文件的路径。如果您尚未安装 MPV,可以在这里下载,或使用您操作系统支持的任何包管理器安装。输入路径后,重启应用程序。

  2. 重启应用程序后,系统会提示您选择服务器。点击"打开菜单"按钮并选择"管理服务器"。在弹出窗口中点击"添加服务器"按钮,填写所有适用的详细信息。您需要输入服务器的完整 URL,包括协议和端口(如果适用)(例如 https://navidrome.my-server.comhttp://192.168.0.1:4533)。

  • Navidrome - 为获得最佳体验,创建服务器时选择"保存密码",并在 Navidrome 配置中将 SessionTimeout 设置为更大的值(例如 72h)。
    • Linux 用户 - 默认密码存储使用 libsecret。也支持 kwallet4/5/6,但必须在设置 > 窗口 > 密码/密钥存储中明确设置。
  1. 可选 - 如果您想在子路径(非 /)上托管 Feishin,请传入以下环境变量:PUBLIC_PATH=PATH。例如,要在 /feishin 上托管,传入 PUBLIC_PATH=/feishin

  2. 可选 - 要硬编码服务器 URL,请传入以下环境变量:SERVER_NAMESERVER_TYPEjellyfinnavidrome 之一)、SERVER_URL。要防止用户更改这些设置,传入 SERVER_LOCK=true。只有在设置了前三个值时才能设置此项。

常见问题

MPV 不工作或在暂停/播放状态之间快速切换

首先要检查 MPV 二进制路径是否正确。导航到设置页面,重新设置路径并重启应用程序。如果问题仍未解决,请尝试重新安装 MPV。已知可用的版本包括 v0.35.xv0.36.xv0.34.x 是已知的有问题版本。

Feishin 支持哪些音乐服务器?

Feishin 支持任何实现 NavidromeJellyfin API 的音乐服务器。目前不支持 Subsonic API。这可能会在新的 Subsonic API 确定后添加

在 Linux 上遇到 "The SUID sandbox helper binary was found, but is not configured correctly" 问题

这是因为您禁用了用户(非特权)命名空间(sysctl kernel.unprivileged_userns_clone 返回 0)。您可以通过启用非特权命名空间或将 chrome-sandbox 设为 Setuid 来解决此问题。

chmod 4755 chrome-sandbox sudo chown root:root chrome-sandbox

开发

使用 Node v16.15.0 构建和测试。

本项目基于 electron-react-boilerplate v4.6.0 构建。

翻译

本项目使用 Weblate 进行翻译。如果您想贡献,请访问该链接并提交翻译。

许可证

GNU 通用公共许可证第3版 ©

编辑推荐精选

音述AI

音述AI

全球首个AI音乐社区

音述AI是全球首个AI音乐社区,致力让每个人都能用音乐表达自我。音述AI提供零门槛AI创作工具,独创GETI法则帮助用户精准定义音乐风格,AI润色功能支持自动优化作品质感。音述AI支持交流讨论、二次创作与价值变现。针对中文用户的语言习惯与文化背景进行专门优化,支持国风融合、C-pop等本土音乐标签,让技术更好地承载人文表达。

QoderWork

QoderWork

阿里Qoder团队推出的桌面端AI智能体

QoderWork 是阿里推出的本地优先桌面 AI 智能体,适配 macOS14+/Windows10+,以自然语言交互实现文件管理、数据分析、AI 视觉生成、浏览器自动化等办公任务,自主拆解执行复杂工作流,数据本地运行零上传,技能市场可无限扩展,是高效的 Agentic 生产力办公助手。

lynote.ai

lynote.ai

一站式搞定所有学习需求

不再被海量信息淹没,开始真正理解知识。Lynote 可摘要 YouTube 视频、PDF、文章等内容。即时创建笔记,检测 AI 内容并下载资料,将您的学习效率提升 10 倍。

AniShort

AniShort

为AI短剧协作而生

专为AI短剧协作而生的AniShort正式发布,深度重构AI短剧全流程生产模式,整合创意策划、制作执行、实时协作、在线审片、资产复用等全链路功能,独创无限画布、双轨并行工业化工作流与Ani智能体助手,集成多款主流AI大模型,破解素材零散、版本混乱、沟通低效等行业痛点,助力3人团队效率提升800%,打造标准化、可追溯的AI短剧量产体系,是AI短剧团队协同创作、提升制作效率的核心工具。

seedancetwo2.0

seedancetwo2.0

能听懂你表达的视频模型

Seedance two是基于seedance2.0的中国大模型,支持图像、视频、音频、文本四种模态输入,表达方式更丰富,生成也更可控。

nano-banana纳米香蕉中文站

nano-banana纳米香蕉中文站

国内直接访问,限时3折

输入简单文字,生成想要的图片,纳米香蕉中文站基于 Google 模型的 AI 图片生成网站,支持文字生图、图生图。官网价格限时3折活动

扣子-AI办公

扣子-AI办公

职场AI,就用扣子

AI办公助手,复杂任务高效处理。办公效率低?扣子空间AI助手支持播客生成、PPT制作、网页开发及报告写作,覆盖科研、商业、舆情等领域的专家Agent 7x24小时响应,生活工作无缝切换,提升50%效率!

堆友

堆友

多风格AI绘画神器

堆友平台由阿里巴巴设计团队创建,作为一款AI驱动的设计工具,专为设计师提供一站式增长服务。功能覆盖海量3D素材、AI绘画、实时渲染以及专业抠图,显著提升设计品质和效率。平台不仅提供工具,还是一个促进创意交流和个人发展的空间,界面友好,适合所有级别的设计师和创意工作者。

图像生成AI工具AI反应堆AI工具箱AI绘画GOAI艺术字堆友相机AI图像热门
码上飞

码上飞

零代码AI应用开发平台

零代码AI应用开发平台,用户只需一句话简单描述需求,AI能自动生成小程序、APP或H5网页应用,无需编写代码。

Vora

Vora

免费创建高清无水印Sora视频

Vora是一个免费创建高清无水印Sora视频的AI工具

下拉加载更多