YesPlayMusic/README.md

238 lines
7.8 KiB
Markdown
Raw Permalink Normal View History

2020-10-10 19:54:44 +08:00
<br />
<p align="center">
2020-12-31 14:39:35 +08:00
<a href="https://music.qier222.com" target="blank">
2020-10-10 19:54:44 +08:00
<img src="images/logo.png" alt="Logo" width="156" height="156">
</a>
<h2 align="center" style="font-weight: 600">YesPlayMusic</h2>
<p align="center">
2020-10-17 00:18:44 +08:00
高颜值的第三方网易云播放器
2020-10-10 19:54:44 +08:00
<br />
2020-12-31 14:39:35 +08:00
<a href="https://music.qier222.com" target="blank"><strong>🌎 访问DEMO</strong></a>&nbsp;&nbsp;|&nbsp;&nbsp;
2022-01-03 15:45:59 +08:00
<a href="#%EF%B8%8F-安装" target="blank"><strong>📦️ 下载安装包</strong></a>&nbsp;&nbsp;|&nbsp;&nbsp;
<a href="https://t.me/yesplaymusic" target="blank"><strong>💬 加入交流群</strong></a>
2020-10-10 19:54:44 +08:00
<br />
<br />
</p>
</p>
2020-12-31 14:39:35 +08:00
[![Library][library-screenshot]](https://music.qier222.com)
2020-10-10 19:54:44 +08:00
## ✨ 特性
- ✅ 使用 Vue.js 全家桶开发
2021-06-10 23:43:04 +08:00
- 🔴 网易云账号登录(扫码/手机/邮箱登录)
2021-03-07 23:16:02 +08:00
- 📺 支持 MV 播放
2021-01-20 14:02:32 +08:00
- 📃 支持歌词显示
2021-06-10 23:43:04 +08:00
- 📻 支持私人 FM / 每日推荐歌曲
2020-10-10 19:54:44 +08:00
- 🚫🤝 无任何社交功能
2020-11-23 20:10:49 +08:00
- 🌎️ 海外用户可直接播放(需要登录网易云账号)
- 🔐 支持 [UnblockNeteaseMusic](https://github.com/UnblockNeteaseMusic/server#音源清单),自动使用[各类音源](https://github.com/UnblockNeteaseMusic/server#音源清单)替换变灰歌曲链接 (网页版不支持)
- 「各类音源」指默认启用的音源。
- YouTube 音源需自行安装 `yt-dlp`
2021-01-20 14:02:32 +08:00
- ✔️ 每日自动签到(手机端和电脑端同时签到)
- 🌚 Light/Dark Mode 自动切换
2020-12-31 14:39:35 +08:00
- 👆 支持 Touch Bar
2021-01-20 14:02:32 +08:00
- 🖥️ 支持 PWA可在 Chrome/Edge 里点击地址栏右边的 安装到电脑
2021-03-23 23:43:29 +08:00
- 🟥 支持 Last.fm Scrobble
2021-06-10 23:43:04 +08:00
- ☁️ 支持音乐云盘
- ⌨️ 自定义快捷键和全局快捷键
2022-05-10 12:10:47 +08:00
- 🎧 支持 Mpris
2020-10-10 19:54:44 +08:00
- 🛠 更多特性开发中
2020-11-23 20:10:49 +08:00
## 📦️ 安装
Electron 版本由 [@hawtim](https://github.com/hawtim) 和 [@qier222](https://github.com/qier222) 适配并维护,支持 macOS、Windows、Linux。
访问本项目的 [Releases](https://github.com/qier222/YesPlayMusic/releases)
页面下载安装包。
2020-11-23 20:10:49 +08:00
- macOS 用户可以通过 Homebrew 来安装:`brew install --cask yesplaymusic`
- Windows 用户可以通过 Scoop 来安装:`scoop install extras/yesplaymusic`
2021-03-07 23:16:02 +08:00
## ⚙️ 部署至 Vercel
2020-11-23 20:10:49 +08:00
2021-04-27 18:24:38 +08:00
除了下载安装包使用,你还可以将本项目部署到 Vercel 或你的服务器上。下面是部署到 Vercel 的方法。
2020-10-10 19:54:44 +08:00
2022-05-10 12:10:47 +08:00
本项目的 Demo (https://music.qier222.com) 就是部署在 Vercel 上的网站。
2022-05-20 00:07:55 +08:00
[![Powered by Vercel](https://www.datocms-assets.com/31049/1618983297-powered-by-vercel.svg)](https://vercel.com/?utm_source=ohmusic&utm_campaign=oss)
2022-05-10 12:10:47 +08:00
1. 部署网易云 API详情参见 [Binaryify/NeteaseCloudMusicApi](https://neteasecloudmusicapi.vercel.app/#/?id=%e5%ae%89%e8%a3%85)
。你也可以将 API 部署到 Vercel。
2021-01-26 11:58:00 +08:00
2021-03-07 23:16:02 +08:00
2. 点击本仓库右上角的 Fork复制本仓库到你的 GitHub 账号。
2020-10-10 19:54:44 +08:00
3. 点击仓库的 Add File选择 Create new file输入 `vercel.json`,将下面的内容复制粘贴到文件中,并将 `https://your-netease-api.example.com` 替换为你刚刚部署的网易云 API 地址:
```json
{
"rewrites": [
{
"source": "/api/:match*",
"destination": "https://your-netease-api.example.com/:match*"
}
]
}
```
4. 打开 [Vercel.com](https://vercel.com),使用 GitHub 登录。
2020-10-10 19:54:44 +08:00
5. 点击 Import Git Repository 并选择你刚刚复制的仓库并点击 Import。
2020-10-10 19:54:44 +08:00
6. 点击 PERSONAL ACCOUNT 旁边的 Select。
2020-10-10 19:54:44 +08:00
7. 点击 Environment Variables填写 Name 为 `VUE_APP_NETEASE_API_URL`Value 为 `/api`,点击 Add。最后点击底部的 Deploy 就可以部署到
Vercel 了。
2020-10-10 19:54:44 +08:00
2021-04-27 18:24:38 +08:00
## ⚙️ 部署到自己的服务器
除了部署到 Vercel你还可以部署到自己的服务器上
1. 部署网易云 API详情参见 [Binaryify/NeteaseCloudMusicApi](https://github.com/Binaryify/NeteaseCloudMusicApi)
2. 克隆本仓库
```sh
git clone --recursive https://github.com/qier222/YesPlayMusic.git
2021-04-27 18:24:38 +08:00
```
3. 安装依赖
```sh
yarn install
```
4. (可选)使用 Nginx 反向代理 API将 API 路径映射为 `/api`,如果 API 和网页不在同一个域名下的话(跨域),会有一些 bug。
5. 复制 `/.env.example` 文件为 `/.env`,修改里面 `VUE_APP_NETEASE_API_URL` 的值为网易云 API 地址。本地开发的话可以填写 API 地址为 `http://localhost:3000`YesPlayMusic 地址为 `http://localhost:8080`。如果你使用了反向代理 API可以填写 API 地址为 `/api`
```
VUE_APP_NETEASE_API_URL=http://localhost:3000
```
6. 编译打包
```sh
yarn run build
```
7.`/dist` 目录下的文件上传到你的 Web 服务器
## ⚙️ Docker 部署
1. 构建 Docker Image
```sh
docker build -t yesplaymusic .
```
2. 启动 Docker Container
```sh
docker run -d --name YesPlayMusic -p 80:80 yesplaymusic
```
3. Docker Compose 启动
```sh
docker-compose up -d
```
YesPlayMusic 地址为 `http://localhost`
2021-03-07 23:16:02 +08:00
## 👷‍♂️ 打包客户端
2020-10-10 19:54:44 +08:00
2021-03-07 23:16:02 +08:00
如果在 Release 页面没有找到适合你的设备的安装包的话,你可以根据下面的步骤来打包自己的客户端。
2020-10-10 19:54:44 +08:00
1. 打包 Electron 需要用到 Node.js 和 Yarn。可前往 [Node.js 官网](https://nodejs.org/zh-cn/) 下载安装包。安装 Node.js
后可在终端里执行 `npm install -g yarn` 来安装 Yarn。
2020-10-10 19:54:44 +08:00
2. 使用 `git clone --recursive https://github.com/qier222/YesPlayMusic.git` 克隆本仓库到本地。
2021-03-07 23:16:02 +08:00
3. 使用 `yarn install` 安装项目依赖。
2021-03-09 17:53:36 +08:00
4. 复制 `/.env.example` 文件为 `/.env`
5. 选择下列表格的命令来打包适合的你的安装包,打包出来的文件在 `/dist_electron` 目录下。了解更多信息可访问 [electron-builder 文档](https://www.electron.build/cli)
2021-03-07 23:16:02 +08:00
| 命令 | 说明 |
| ------------------------------------------ | ------------------------- |
| `yarn electron:build --windows nsis:ia32` | Windows 32 位 |
| `yarn electron:build --windows nsis:arm64` | Windows ARM |
| `yarn electron:build --linux deb:armv7l` | Debian armv7l树莓派等 |
| `yarn electron:build --macos dir:arm64` | macOS ARM |
2020-10-10 19:54:44 +08:00
## :computer: 配置开发环境
本项目由 [NeteaseCloudMusicApi](https://github.com/Binaryify/NeteaseCloudMusicApi) 提供 API。
运行本项目
```shell
# 安装依赖
yarn install
# 创建本地环境变量
cp .env.example .env
# 运行(网页端)
yarn serve
# 运行electron
yarn electron:serve
```
本地运行 NeteaseCloudMusicApi或者将 API [部署至 Vercel](#%EF%B8%8F-部署至-vercel)
```shell
# 运行 API (默认 3000 端口)
yarn netease_api:run
```
2020-10-10 19:54:44 +08:00
## ☑️ Todo
2020-10-25 22:02:21 +08:00
查看 Todo 请访问本项目的 [Projects](https://github.com/qier222/YesPlayMusic/projects/1)
2020-10-10 19:54:44 +08:00
2020-10-25 22:02:21 +08:00
欢迎提 Issue 和 Pull request。
2020-10-10 19:54:44 +08:00
## 📜 开源许可
2021-01-26 11:58:00 +08:00
本项目仅供个人学习研究使用,禁止用于商业及非法用途。
2020-10-10 19:54:44 +08:00
基于 [MIT license](https://opensource.org/licenses/MIT) 许可进行开源。
2021-01-29 22:10:58 +08:00
## 灵感来源
2021-03-07 23:16:02 +08:00
API 源代码来自 [Binaryify/NeteaseCloudMusicApi](https://github.com/Binaryify/NeteaseCloudMusicApi)
2021-01-29 22:10:58 +08:00
- [Apple Music](https://music.apple.com)
- [YouTube Music](https://music.youtube.com)
- [Spotify](https://www.spotify.com)
- [网易云音乐](https://music.163.com)
2020-10-10 19:54:44 +08:00
## 🖼️ 截图
2021-06-10 23:43:04 +08:00
![lyrics][lyrics-screenshot]
![library-dark][library-dark-screenshot]
![album][album-screenshot]
![home-2][home-2-screenshot]
![artist][artist-screenshot]
![search][search-screenshot]
![home][home-screenshot]
![explore][explore-screenshot]
2020-10-10 19:54:44 +08:00
<!-- MARKDOWN LINKS & IMAGES -->
<!-- https://www.markdownguide.org/basic-syntax/#reference-style-links -->
[album-screenshot]: images/album.png
[artist-screenshot]: images/artist.png
[explore-screenshot]: images/explore.png
[home-screenshot]: images/home.png
2021-06-10 23:43:04 +08:00
[home-2-screenshot]: images/home-2.png
[lyrics-screenshot]: images/lyrics.png
2020-10-10 19:54:44 +08:00
[library-screenshot]: images/library.png
2021-06-10 23:43:04 +08:00
[library-dark-screenshot]: images/library-dark.png
2020-10-10 19:54:44 +08:00
[search-screenshot]: images/search.png