2025-10-04 13:32:46 +08:00
2025-10-04 14:45:22 +08:00
2024-04-17 16:56:43 +08:00
2025-10-04 14:45:22 +08:00
2024-01-09 08:28:04 +00:00
2025-10-04 15:07:38 +08:00
2025-10-04 14:45:22 +08:00

ncmdump

使用本程序可将下载的网易云音乐缓存文件ncm转换为 mp3 或 flac 格式

简介

该版本为最早的 C++ 版本,也是作者开发的市面上第一个支持 ncm 转换的程序

源码复刻自 anonymous5l/ncmdump (2021年10月6日原作者已经删库)

感谢前辈的付出!此版本做了全操作系统下的的跨平台编译移植,修复了一些内存溢出的问题。

1.3.0 版本更新说明:因为之前有较多 Issue 反馈无法解密带有特殊字符的文件名例如中文、日文、韩文或者是表情符号等在1.3.0以及之后的版本彻底修复了这个问题,所有的 UTF-8 字符都可以正常解密。并且还自带了 dll 的构建可以供其他应用程序C#、Python、Java等调用。

使用

注意:网易云音乐 3.0 之后的某些版本,下载的 ncm 文件会出现不内置歌曲专辑的封面图片的情况,所需的封面图数据需要从网络获取,介于在一个小工具中嵌入庞大网络库的非必要性,可以移步我的另一个仓库 ncmdump-go 或者使用基于此项目开发的可视化 GUI 程序 ncmdump-gui,其中后者基于前者,均完全使用 Golang 重写,并支持自动从元数据读取封面信息后从网络获取封面图并嵌入到目标音乐文件。

命令行工具

Release 下载最新版本的对应系统的已编译好的二进制文件

使用 -h--help 参数来打印帮助

ncmdump -h

使用 -v--version 参数来打印版本信息

ncmdump -v

处理单个或多个文件

ncmdump 1.ncm 2.ncm...

使用 -d 参数来指定一个文件夹,对文件夹下的所有以 ncm 为扩展名的文件进行批量处理

ncmdump -d source_dir

使用 -r 配合 -d 参数来递归处理文件夹下的所有以 ncm 为扩展名的文件

ncmdump -d source_dir -r

使用 -o 参数来指定输出目录,将转换后的文件输出到指定目录,该参数支持与 -r 参数一起使用

# 处理单个或多个文件并输出到指定目录
ncmdump 1.ncm 2.ncm -o output_dir

# 处理文件夹下的所有以 ncm 为扩展名并输出到指定目录,不包含子文件夹
ncmdump -d source_dir -o output_dir

# 递归处理文件夹并输出到指定目录,并保留目录结构
ncmdump -d source_dir -o output_dir -r

动态库

或者,如果你想利用此项目进行二次开发,例如在你的 C#、Python、Java 等项目中调用,你可以使用 libncmdump 动态库,具体使用方法见仓库的 example 文件夹

请注意!如果你在 Windows 下开发,传递到库构造函数的文件名编码必须为 UTF-8 编码,否则会抛出运行时错误。

编译项目

克隆本仓库

git clone https://github.com/taurusxin/ncmdump.git

使用 CMake 配置项目。Windows 下若使用 GNU 套件,推荐使用 msys2 或者 winlibs

注意:从 1.6 版本开始CMake 构建不再依赖于 gitmodule因此无需再克隆 taglib 仓库,改为使用系统的 taglib 库,针对不同系统上的构建,请参照如下方法

Windows

首先需要安装 Visual Studio 2022 和 cmake并安装 C++ 桌面开发环境,然后安装 vcpkg

# 安装 vcpkg 并安装 taglib 的静态库
git clone https://github.com/microsoft/vcpkg.git
cd vcpkg
./bootstrap-vcpkg.bat

./vcpkg install taglib:x64-windows-static

进入源码目录并配置项目

# 使用 cmake 配置项目,替换 %VCPKG_ROOT% 为你的 vcpkg 安装路径
cmake -G "Visual Studio 17 2022" -DCMAKE_TOOLCHAIN_FILE=%VCPKG_ROOT%/scripts/buildsystems/vcpkg.cmake -DVCPKG_TARGET_TRIPLET=x64-windows-static -B build

# 编译项目
cmake --build build -j 8 --config Release

macOS / Linux

macOS 下,你可以使用 Homebrew 来安装 taglib 库Linux 下,你可以使用 apt / pacman 等包管理器来安装 taglib 库

# 安装 taglib 库
# macOS
brew install taglib
# Linux (Debian / Ubuntu)
sudo apt install libtag1-dev

# 配置项目
cmake -DCMAKE_BUILD_TYPE=Release -B build

# 编译项目
cmake --build build -j 8

你可以在 build 文件夹下找到编译好的二进制文件,以及一个可供其它项目使用的动态库(Windows Only),使用方法见仓库的 example 文件夹

Star History

Star History Chart

Description
No description provided
Readme 2.2 MiB
Release 1.5.1 Latest
2025-10-05 15:24:05 +08:00
Languages
C++ 89.1%
C 8.2%
C# 1.6%
CMake 1.1%