git commit 执行报错 sh: -/: invalid option

目录

  • 目录
    • [1. 检查 Git 钩子脚本(核心步骤)](#1. 检查 Git 钩子脚本(核心步骤))
    • [2. 临时绕过钩子(快速提交)](#2. 临时绕过钩子(快速提交))
    • [3. 修复钩子依赖环境](#3. 修复钩子依赖环境)
    • [4. 重新初始化 Husky(如适用)](#4. 重新初始化 Husky(如适用))
    • [5. 验证用户配置](#5. 验证用户配置)

Tips: 如果是 clone 下来的新项目直接进行 步骤 4


1. 检查 Git 钩子脚本(核心步骤)

  • 问题根源:.git/hooks/pre-commit 或其他钩子脚本的开头可能包含无效的 Shebang 行(如 #!/bin/sh -/)或语法错误。
  • 解决方法:
    1. 进入项目根目录的 .git/hooks 文件夹:

      bash 复制代码
      cd .git/hooks 
    2. 检查 pre-commit 文件(或其他钩子)的开头行:

      bash 复制代码
      head -n 1 pre-commit 
    3. 修正 Shebang 行:确保首行为 #!/bin/sh#!/usr/bin/env sh,删除多余的符号(如 -/)。

    4. 检查脚本内容:若脚本包含类似 - /path/to/node 的无效参数,需修正为合法命令(如 node script.js)。


2. 临时绕过钩子(快速提交)

若需紧急提交,可跳过钩子检查:

bash 复制代码
git commit --no-verify -m "提交信息"

注意:此操作会忽略代码规范检查(如 ESLint),仅建议临时使用。


3. 修复钩子依赖环境

  • Node.js 路径问题:若钩子调用 Node 命令但系统未识别:

    • 确认 Node 已安装:node -v
    • 在 Shebang 行使用完整路径(如 #!/usr/bin/env node)。
  • 权限问题:确保钩子文件可执行:

    bash 复制代码
    chmod +x .git/hooks/pre-commit 

4. 重新初始化 Husky(如适用)

若使用 Husky 管理钩子:

  1. 删除 .git/hooks 目录:

    bash 复制代码
    rm -rf .git/hooks 
  2. 重新安装 Husky:

    bash 复制代码
    npx husky install 
  3. 重建钩子链接:

    bash 复制代码
    npx husky add .husky/pre-commit "npm test"

5. 验证用户配置

确保 Git 全局配置正确(虽非直接原因,但需排除干扰):

bash 复制代码
git config --global user.name "Your Name"
git config --global user.email "email@example.com"

总结步骤优先级:

  1. 检查并修正钩子脚本语法(尤其是 Shebang 行)→ 解决 90% 问题。
  2. 临时用 --no-verify 提交 → 快速绕过。
  3. 重装 Husky 或修复依赖环境 → 适用于工具链问题。
  4. 验证基础配置 → 排除其他干扰。
相关推荐
anOnion7 分钟前
构建无障碍组件之Menu Button pattern
前端·html·交互设计
用户479492835691524 分钟前
claude Fable用不了?把Gpt 5.5pro接到你的claude code里
前端·后端
JieE21243 分钟前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
冬奇Lab3 小时前
AI Workflow 定义的四次演进:从 Markdown 到 JS 脚本,再到分布式多 Agent
javascript·人工智能·agent
zhangxingchao3 小时前
Kotlin常用的Flow 操作符整理
前端
IT_陈寒5 小时前
React的useState居然还有这种坑?我差点删库跑路
前端·人工智能·后端
Pedantic6 小时前
SwiftUI 手势笔记
前端·后端
橙子家6 小时前
浏览器缓存之【结构化数据库与缓存】: IndexedDB、Cache storage 和 Storage buckets
前端
user20585561518136 小时前
X6 中边悬浮置顶,规避 `mouseleave` 事件丢失问题
前端
李明卫杭州6 小时前
CSS aspect-ratio 属性完全指南
前端