Skip to main content

在 macOS 上成功读写 ntfs 磁盘的完整步骤

在 macOS 上成功读写 ntfs 磁盘的完整步骤:

#macOS,#homebrew,#brew,#macFUSE,#ntfs-3g,#ntfs,

  1. 安装 Homebrew

    /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"
    /opt/homebrew/bin/brew update --force --quiet
    echo >> $HOME'/.zprofile'
    echo 'eval "$(/opt/homebrew/bin/brew shellenv)"' >> $HOME'/.zprofile'
    eval "$(/opt/homebrew/bin/brew shellenv)"
    
  2. 安装依赖项

    brew install autoconf automake libtool pkg-config
    brew install gettext
    brew link gettext --force
    
  3. 安装 macFUSE

  4. 修改安全策略

    • 打开 系统偏好设置,选择 安全性与隐私,在 安全 栏中启用系统扩展。
    • 点击 关机,长按 Command + R电源 进入恢复模式。
    • 实用工具 一栏,点击 启动安全性实用工具
    • 点击 安全策略,取消勾选 完整安全性,勾选 降低安全性,并勾选 允许用户管理来自被认可开发者的内核扩展,点击
    • 重新启动你的 Mac。
  5. 下载 ntfs-3g 源代码

    git clone https://github.com/tuxera/ntfs-3g.git
    cd ntfs-3g
    
  6. 安装 libgcrypt

    brew install libgcrypt
    
  7. 确保 aclocal 可以找到 gcrypt.m4 文件

    export ACLOCAL_PATH=$(brew --prefix libgcrypt)/share/aclocal
    
  8. 编译和安装 ntfs-3g

    ./autogen.sh
    ./configure --exec-prefix=/usr/local
    make && sudo make install
    
  9. 如果想重新编译,在重新编译之前,建议清理之前的构建文件。可以使用以下命令来清理构建文件

    # 这个命令会删除之前编译生成的文件,确保你有一个干净的环境来重新编译项目。
    make clean
    # 如果你想彻底清理所有生成的文件,可以使用以下命令:
    # 这个命令会删除所有生成的文件,包括配置文件和中间文件。
    make distclean
    # 然后重新执行安装步骤
    ./autogen.sh
    ./configure --exec-prefix=/usr/local
    make && sudo make install
    
  10. 安装挂载程序,方便挂载ntfs磁盘

xattr -d com.apple.quarantine /Applications/nigate.app

这些步骤应该可以帮助你在 macOS 上安装 macFUSE 扩展,成功编译和安装 ntfs-3g 驱动,并将其安装到指定的路径,再借助挂载程序 Free-NTFS-for-Mac 识别稍等片刻即可读写你的 ntfs 磁盘。如果遇到任何问题,可以参考以下资源:

Comments

Popular posts from this blog

python学习之路☞9.Comment, Primitive Data Types and Branch Conditional Structure if ... else ...

python学习之路☞9.Comment, Primitive Data Types and Branch / Conditional Structure if … else … #python,#Comment,#data type,#branch/conditional structure,#input(),#int,#float,#complex,#boolean,#if … else …, 注释(Comment) 内置函数input()(input() Function) 基本数据类型整数(Primitive Data Types int) 基本数据类型小数(Primitive Data Types float) 基本数据类型复数(Primitive Data Types complex) 基本数据类型布尔(Primitive Data Types boolean) 分支结构if … else …(Branch / Conditional Structure if … else …) 参考 Comment ''' 注释: 给人看的说明文字,Python 解释器完全忽略 要点 # 让该行 # 之后的内容全部失效,解释器跳过。 行尾注释与代码在同一行,通常用于简短说明。 docstring(三引号字符串)放在函数/类/模块第一行时,可被 help() 和文档工具读取,有特殊意义。 好的注释解释"为什么",而不是"做了什么"(代码本身已经说明了做了什么): # ✗ i = i + 1 # i 加 1 # ✓ i += 1 # 跳过表头行 ''' # 这是单行注释,# 号后面全部忽略 x = 10 # 行尾注释,代码照常执行 # 多行注释:每行都加 # # 第一行说明 # 第二行说明 # 第三行说明 """ 这是多行字符串(docstring) 虽然常被当注释用, 但本质是字符串字面量,不是注释。 通常用于函数/类的文档说明。 """ def add ( a , b ) : """返回 a 与 b 的和。"...

OnePlus 7 Pro LineageOS 23.2 Android 16 构建与内核 Docker 支持并在 Termux 上实现容器运行全流程指南

OnePlus 7 Pro LineageOS 23.2 Android 16 构建与内核 Docker 支持并在 Termux 上实现容器运行全流程指南 OnePlus 7 Pro LineageOS 23.2 Android 16 构建与内核 Docker 支持并在 Termux 上实现容器运行全流程指南 #docker,#linux,#termux,#android,#kernel,#lineageos,#oneplus,#git,#android16, gmkm6 x86_64 主机配置环境 安装配置 docker 防止污染环境 更新 docker 插件 compose 更新 docker 插件 buildx 创建编译容器 容器内编译镜像刷机 安装magisk,termux获取root termux检测内核docker缺失功能 根据内核docker缺失功能编译boot.img并获取root 开启全部必要扩展功能 下面的步骤是开启大部分非必要扩展功能 修补内核代码方案 下面的步骤是开启剩余部分非必要扩展功能 修补内核 安装测试运行 termux docker 其它关于termux的docker-compose和docker-buildx更新 安装用于校验的工具 开机自启动和容器化部署使用例子 Android16尝试开启KVM失败的例子(不用试了,唉) 内核修补 参考&感谢 gmkm6 x86_64 主机配置环境 注意,获取自己的手机型号代号,这一点很重要在后续的命令中都要用到 比如我的手机 oneplus7pro 是 guacamole 也可以尝试通过命令获取获取,但是我不知道是不是所有设备都是这样获取的 adb shell getprop ro.boot.project_codename 最重要的是,一定要找好固件包,免得变成砖头,有线刷包就可以怎么折腾都不怕 听我说,编译内核是一件很枯燥的核对过程,这个过程需要考虑到各项之间的互相依赖和冲突并以此作出取舍 这不是个简单的过程,这里只展示具有逻辑的依赖项,需要耐心和不断的试错总结 不得不说设计的内核是一件件精美的艺术品,从某种意义上来讲,万事万物皆为艺术,而探索艺术本身是...

OnePlus 7 Pro LineageOS 19.1 构建与内核 Docker 支持并在 Termux 上实现容器运行全流程指南

OnePlus 7 Pro LineageOS 19.1 构建与内核 Docker 支持并在 Termux 上实现容器运行全流程指南 OnePlus 7 Pro LineageOS 19.1 构建与内核 Docker 支持并在 Termux 上实现容器运行全流程指南 #docker,#linux,#termux,#android,#kernel,#lineageos,#oneplus,#git, gmkm6 x86_64 主机配置环境 安装配置 docker 防止污染环境 更新 docker 插件 compose 更新 docker 插件 buildx 创建编译容器 容器内编译镜像刷机 安装magisk,termux获取root termux检测内核docker缺失功能 根据内核docker缺失功能编译boot.img并获取root 安装测试运行 termux docker 其它关于termux的docker-compose和docker-buildx更新 参考&感谢 注意,获取自己的手机型号代号,这一点很重要在后续的命令中都要用到 比如我的手机 oneplus7pro 是 guacamole 也可以尝试通过命令获取获取,但是我不知道是不是所有设备都是这样获取的 adb shell getprop ro.boot.project_codename 最重要的是,一定要找好固件包,免得变成砖头,有线刷包就可以怎么折腾都不怕 最近 OP7P 设备型号是 guacamole 手机刷了 GM1910_11_H.40 即 android 12 https://gauss-componentotacostmanual-sg.allawnofs.com/remove-d74c973c240292cb011317bb07f424a2/component-ota/23/03/28/6d4604798d27450e8de05671d5effbae.zip 内核版本 4.14.180-perf+ 发现 github.com/OnePlusOSS 官方有相关的开放残缺的内核源码,但缺失了很多代码配置 https://github.com/OnePlusOSS/android_kernel_o...