Git提交代码报错fatal: detected dubious ownership ...

贴出报错信息

复制代码
错误:fatal: detected dubious ownership in repository at 'D:/workspace/icbc'
'D:/workspace/icbc' is owned by:
feiji/Administrators (S-1-5-32-544)
but the current user is:
DESKTOP-2N2NI2S/song (S-1-5-21-978294077-503222281-1621980191-1001)
To add an exception for this directory, call:
git config --global --add safe.directory D:/workspace/icbc

这个错误是 Git 为了保护你的系统安全而新增的一项机制(从 Git 2.35.2 版本开始引入)。简单来说,Git 发现你当前登录的 Windows 用户(song)和这个代码仓库文件夹的所有者(Administrators)不一致,因此为了防止潜在的恶意代码执行,它拒绝运行。

方案一:添加到安全目录

打开git输入命令

复制代码
git config --global --add safe.directory D:/workspace/icbc

如果目录很多可以使用以下命令添加所有目录

复制代码
git config --global --add safe.directory '*'

方案二:修复文件夹所有权

方案一只是"掩耳盗铃",方案二是真正把文件夹的归属权拿回来。这通常发生在你曾经用管理员身份运行过命令行拉取代码,或者复制了别人的文件。

在 Windows 上操作如下:

  1. 右键点击 D:/workspace/icbc 文件夹,选择 "属性"
  2. 切换到 "安全" 选项卡,点击 "高级" 按钮。
  3. 在"所有者"旁边点击 "更改"
  4. 在"输入要选择的对象名称"框里,输入你当前的用户名(即报错信息里的 song),或者输入 Everyone
    • 不知道用户名? 点击"高级" -> "立即查找",在下方列表中选择你的账户(通常是 song)。
  5. 勾选 "替换子容器和对象的所有者"
  6. 点击"应用" -> "确定"。
  7. 权限更新后,再次运行 git 命令应该就能正常工作了。

偷懒方法(使用命令行)

如果你熟悉命令行,可以在 PowerShell(管理员模式)中运行以下命令来批量修复:

bash 复制代码
# 获取当前用户SID
$mySid = [System.Security.Principal.WindowsIdentity]::GetCurrent().User.Value
# 接管目录所有权(请将路径替换为你的实际路径)
TakeOwn /F "D:/workspace/song" /R /D Y
# 设置完全控制权限
icacls "D:/workspace/zxzx_account" /grant:r "$($env:USERDOMAIN)\$($env:USERNAME):(OI)(CI)F" /T

为什么会这样?

了解原因有助于你避免下次再遇到:

  • 权限不匹配: 你的文件夹被标记为属于 Administrators 组,而你当前是以普通用户 song 登录的。
  • 安全考量: Git 担心黑客可能利用这个权限差异,在你不知情的情况下执行恶意脚本。
  • exFAT/FAT32 硬盘: 如果你的 D: 盘是移动硬盘或格式化为 exFAT/FAT32 的分区,它们不支持 Linux/NTFS 那样的精细权限管理,Git 也会报这个错。这种情况下,方案一(加白名单)是唯一实用的解决办法。

总结

场景 推荐方案
个人开发机,只有你一个人用 方案一 (加 safe.directory),省事且安全。
公司电脑/服务器,多人共用 方案二(修复所有权),更符合安全规范。
移动硬盘/U盘 开发 方案一,因为移动硬盘格式通常无法记录所有权。
相关推荐
摇滚侠1 小时前
MAC IDEA GIT 提交区显示了几个不存在的目录
git·idea
城东2 小时前
Git使用[远程仓库远端的head比本地和提交的head旧,其他人拉不到最新代码]
git·head·远程仓库远端·比本地和提交的head旧·其他人拉不到最新代码
何中应11 小时前
使用SSH地址拉取远程仓库代码报下面的错误
git
何中应11 小时前
Git本地仓库命令补充
git
sun00770013 小时前
执行repo sync -c -d -j4以后,提交未git push的代码看不到了。要怎么恢复?
git
胖虎115 小时前
Git 一个本地仓库同时推送到两个远程仓库(详细教程)
git·多远程仓库·双远程仓库·git双远程·git备份
春日见1 天前
如何创建一个PR
运维·开发语言·windows·git·docker·容器
stevenzqzq2 天前
git 常用操作
大数据·git
Curvatureflight2 天前
Git工作流最佳实践:从混乱到优雅
git
wu~9702 天前
GitHub永不遗忘,使用git push -f来覆盖的提交依旧保留
git·github