mirror of
https://git.unlock-music.dev/um/um-react.git
synced 2024-11-24 00:02:16 +00:00
82 lines
3.6 KiB
Markdown
82 lines
3.6 KiB
Markdown
# Unlock Music 音乐解锁 (React)
|
||
|
||
[![Build Status](https://ci.unlock-music.dev/api/badges/um/um-react/status.svg)](https://ci.unlock-music.dev/um/um-react)
|
||
|
||
- 在浏览器中解锁加密的音乐文件。 Unlock encrypted music file in the browser.
|
||
- 查看[原基于 Vue 的 Unlock Music 项目][um-vue]
|
||
- Unlock Music 项目是以学习和技术研究的初衷创建的,修改、再分发时请遵循[授权协议]。
|
||
- Unlock Music 的 CLI 版本可以在 [unlock-music/cli] 找到,大批量转换建议使用 CLI 版本。
|
||
- 我们新建了 Telegram 群组 [`@unlock_music_chat`] ,欢迎加入!
|
||
- CI 自动构建已经部署,可以在 [Packages][um-react-packages] 下载。
|
||
- [常见问题参考](./docs/faq_zh-hans.md)
|
||
|
||
[授权协议]: https://git.unlock-music.dev/um/um-react/src/branch/main/LICENSE
|
||
[um-vue]: https://git.unlock-music.dev/um/web
|
||
[unlock-music/cli]: https://git.unlock-music.dev/um/cli
|
||
[`@unlock_music_chat`]: https://t.me/unlock_music_chat
|
||
[um-react-packages]: https://git.unlock-music.dev/um/-/packages/generic/um-react/
|
||
|
||
## 支持的格式
|
||
|
||
- [x] QQ 音乐 QMCv1 (..qmc3/.qmcflac 等)
|
||
- [x] QQ 音乐 QMCv2
|
||
- PC 客户端 (.mflac/.mgg 等) [^qm-key-pc]
|
||
- 安卓客户端 (.mflac0/.mgg1/.mggl 等) [^qm-key-android]
|
||
- iOS 客户端 (.mgalaxy 等) [^qm-key-ios]
|
||
- Mac 客户端 (.mflach 等) [^qm-key-mac]
|
||
- [x] 网易云音乐 (.ncm)
|
||
- [x] 虾米音乐 (.xm)
|
||
- [x] 酷我音乐 (.kwm)
|
||
- [x] 酷狗音乐 (.kgm/.vpr)
|
||
- [x] 喜马拉雅 Android 端 (.x2m/.x3m)
|
||
- [x] 咪咕音乐格式 (.mg3d)
|
||
- [ ] ~~<ruby>QQ 音乐海外版<rt>JOOX Music</rt></ruby> (.ofl_en)~~
|
||
|
||
[^qm-key-pc]: PC 客户端仅支持 v19.43 或更低版本。
|
||
[^qm-key-android]: 需要获取超级管理员权限后提取密钥数据库,并导入后使用。
|
||
[^qm-key-ios]: 需要越狱获取密钥数据库,或对设备进行完整备份后提取密钥数据库,并导入后使用。
|
||
[^qm-key-mac]: 需要导入密钥数据库。
|
||
|
||
不支持的格式?请提交样本(加密文件)与客户端信息(或一并上传其安装包)到[仓库的问题追踪区][project-issues]。如果文件太大,请上传到不需要登入下载的网盘,如 [mega.nz](https://mega.nz)、[OneDrive](https://www.onedrive.com/) 等。
|
||
|
||
如果遇到解密出错的情况,请一并携带错误信息并简单描述错误的重现过程。
|
||
|
||
[project-issues]: https://git.unlock-music.dev/um/um-react/issues/new
|
||
|
||
## 开发相关
|
||
|
||
从源码运行或编译生产版本,请参考文档「[新手上路](./docs/getting-started.zh.md)」。
|
||
|
||
### 面向 libparakeet SDK 开发
|
||
|
||
⚠️ 如果只是进行前端方面的更改,你可以跳过该节。
|
||
|
||
请参考文档「[面向 `libparakeet-js` 开发](./docs/develop-with-libparakeet.zh.md)」。
|
||
|
||
### 架构
|
||
|
||
- 浏览器主线程: 渲染界面,处理 UI 更新
|
||
- Web Worker: 负责计算方面的内容,如内容解密。
|
||
|
||
数据传输: 生成 blob url (`URL.createObjectURL`) 然后透过 `postMessage` 传递给线程,线程利用 `fetch` API 来获取文件信息。
|
||
|
||
### 贡献代码
|
||
|
||
欢迎贡献代码。请确保:
|
||
|
||
- 单元测试的覆盖率不低于主分支的覆盖率;
|
||
- 提交前请使用 Prettier 对代码进行格式化;
|
||
- 提交前请确保 ESLint 不会报告 warning / error;
|
||
|
||
满足上述条件后发起 Pull Request,仓库管理员审阅后将合并到主分支。
|
||
|
||
## TODO
|
||
|
||
- 待定
|
||
- [ ] 各类算法 [追踪 `crypto` 标签](https://git.unlock-music.dev/um/um-react/issues?labels=67)
|
||
- [ ] #7 简易元数据编辑器
|
||
- 完成
|
||
- [x] #8 ~~添加单元测试~~ 框架加上了,以后慢慢添加更多测试即可。
|
||
- [x] #2 解密内容探测 (解密过程)
|
||
- [x] #6 文件拖放 (利用 `react-dropzone`?)
|