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. 验证基础配置 → 排除其他干扰。
相关推荐
CCC:CarCrazeCurator17 小时前
IDE 与编程语言区分介绍
git·github
0思必得017 小时前
[Web自动化] 爬虫合规指南:从法律红线到安全实践
前端·爬虫·自动化·web自动化
qq_1777673717 小时前
React Native鸿蒙跨平台实现移动端图书展示与交互系统,涵盖图书列表渲染、多分类筛选、收藏与购物车管理、图书详情展示等核心业务场景
javascript·react native·react.js·ecmascript·交互·harmonyos
Code小翊17 小时前
Vue 3 核心语法速查
前端·javascript·vue.js
雨季66617 小时前
Flutter 三端应用实战:OpenHarmony “安全文本溢出处理调节器”
开发语言·前端·安全·flutter·交互
Q741_14717 小时前
Git 基础操作速查手册 场景模拟
git·学习·版本控制·总结
雨季66617 小时前
Flutter 三端应用实战:OpenHarmony “极简安全文本对齐调节器”
开发语言·前端·javascript·安全·flutter·交互
肖。354878709418 小时前
html选择页最简模板源码,用于集合很多网页!游戏大全数字导航页面,数字选择页制作灵感,已经压缩到最小,现代,讲解。
android·java·javascript·css·html
qq_1777673718 小时前
React Native鸿蒙跨平台完成动漫应用实现本地数据持久化、收藏管理、观看历史记录、标签页切换
javascript·react native·react.js·ecmascript·harmonyos
木子啊18 小时前
Uni-app跨页面通信三剑客
前端·uni-app·传参