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. 验证基础配置 → 排除其他干扰。
相关推荐
NiceCloud喜云1 小时前
Opus 4.8 的 Effort Control 怎么选:Low 到 Max 五档策略
android·java·大数据·前端·c++·python·spring
wordbaby2 小时前
React Native + RNOH:跨页面数据回传的最佳实践与避坑指南
前端·react native
GISer_Jing2 小时前
Three.js着色器编译机制深度解析
javascript·webgl·着色器
丷丩2 小时前
MapLibre GL JS第22课:查看本地GeoJSON
前端·javascript·map·mapbox·maplibre gl js
油炸自行车2 小时前
Claude Code 错误:API Error: 400 Failed to deserialize the JSON body into the
开发语言·javascript·json·trae·claude code·api error 400
Front思3 小时前
AI前端工程师需要具备能力+
前端·人工智能·ai
ZC跨境爬虫5 小时前
跟着 MDN 学CSS day_29:(掌握文本与字体样式的核心艺术)
前端·css·ui·html·tensorflow
李子琪。6 小时前
网络空间安全深度实战:CSRF 漏洞原理剖析与基于 Token 的纵深防御体系构建(全栈实验报告)
前端·安全·csrf
冰暮流星6 小时前
javascript之history对象介绍
前端·笔记
IT_陈寒6 小时前
Vite热更新失灵?你可能漏了这个配置
前端·人工智能·后端