奥丁9
奥丁9
后端
数据库
redis
mysql
mongoDB
达梦
php
laravel
laravel-admin
dcat
表单
表格
java
spring
python
go
c
c++
前端
vue
nodejs
sass/less
html/css
前端框架
javascript
微信生态
公众号
小程序
uniapp
typescript
其他
AI
数据结构
安全
linux
seo
git
健身
算法
正则表达式
docker
待分类
其他
/
git
git 删除历史提交中的某个文件,包含所有记录,过滤所有记录
1年前
aoding9
70
git
## 原文:[git 删除历史提交中的某个文件,包含所有记录,过滤所有记录](https://blog.csdn.net/KimBing/article/details/124167080) ## 一、问题描述 有时候,我们需要删除 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 中只有最新的提交记录,之前带密码的提交记录已经全部删除了
本作品采用
《CC 协议》
,转载必须注明作者和本文链接