git 删除历史提交中的某个文件,包含所有记录,过滤所有记录

git 删除历史提交中的某个文件,包含所有记录,过滤所有记录

一、问题描述

有时候,我们需要删除历史记录中的某个文件。
比如在你开发一个项目的时候,刚开始是闭源的,里面可能包含一些比较敏感的信息,用户名和密码等,后来想将这个项目开源了,但这些用户名和密码的配置文件已经存在于 git 历史中,这时候就需要用到这个功能

二、解决办法

StackOverflow 解答参阅:https://stackoverflow.com/a/52643437/8086267

实现这个目标,需要用到 git 的 filter-branch 命令,

1. 执行

比如我就有这么个项目,里面的配置文件中包含了一些敏感信息,这样操作:

注意:建议在执行前将对应的文件备份下,以便之后修改并恢复这个文件

git filter-branch -f  --index-filter 'git rm -rf --cached --ignore-unmatch 这里替换成你要删除的文件路径和文件名' HEAD

比如我要删除的文件是 config/configDB.js 后来又重命名成了 config/configDatabase.js,那我就需要进行两次操作

git filter-branch -f  --index-filter 'git rm -rf --cached --ignore-unmatch config/configDB.js' HEAD
git filter-branch -f  --index-filter 'git rm -rf --cached --ignore-unmatch config/configDatabase.js' HEAD

执行指令后,它会等待一会再执行,好让你有个反悔的过程,如果这期间你不按下 ctrl+c撤消键,命令将正常执行。

2. 执行过程:在这里插入图片描述

3. 恢复这个文件

上面已经删除了这个包含敏感信息的文件。再生成一个新的文件,里面的内容中将敏感信息去掉,再提交即可。

4. 强制覆盖线上的 git 记录

完成上述步骤后, 执行以下指令,将本地的提交记录,强制覆盖线上的。

git push origin --force --all

三、结果

可以看到,线上的 git 中只有最新的提交记录,之前带密码的提交记录已经全部删除了
在这里插入图片描述

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值