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. 验证基础配置 → 排除其他干扰。
相关推荐
Mintopia12 分钟前
Vite 发展现状与回顾:从“极致开发体验”到生态基础设施
前端
前端双越老师35 分钟前
前端面试常见的 10 个场景题
前端·面试·求职
孟祥_成都1 小时前
【全网最通俗!新手到AI全栈开发必读】 AI 是如何进化到大模型的
前端·人工智能·全栈
牛奶2 小时前
AI辅助开发的基础概念
前端·人工智能·ai编程
摸鱼的春哥2 小时前
Agent教程15:认识LangChain,Agent框架的王(上)
前端·javascript·后端
明月_清风3 小时前
自定义右键菜单:在项目里实现“选中文字即刻生成新提示”
前端·javascript
明月_清风3 小时前
告别后端转换:高质量批量导出实战
前端·javascript
刘发财7 小时前
弃用html2pdf.js,这个html转pdf方案能力是它的几十倍
前端·javascript·github
牛奶10 小时前
2026年大模型怎么选?前端人实用对比
前端·人工智能·ai编程
牛奶10 小时前
前端人为什么要学AI?
前端·人工智能·ai编程