


















之前在Github上发布过一个项目,今天突然想起来:
有个不该上传的东西被我上传上去了!
于是便修改了源代码,但是在History中还是能看到以前的提交记录!
在网上查找了半天,发现都是使用git filter-branch进行清除,但我的项目有点特殊:
这个敏感信息,早在第一次就提交过了!
而git filter-branch还有其它方法是对项目进行回滚,达到删除Commit记录的目的,对我来说是无效的。
最后发现了一个神器:BFG-Repo-Cleaner
它能清除掉你指定文件/文件夹名在项目中的所有痕迹!
如果你安装了Homebrew,可以使用如下命令安装BFG:
1brew install bfg
使用如下命令使用BFG:
1bfg [命令]
1wget https://repo1.maven.org/maven2/com/madgag/bfg/1.13.0/bfg-1.13.0.jar
使用wget下载BFG。它会在你所在目录出现,你可以通过如下命令使用BFG:
1java -jar bfg-1.13.0.jar [命令]
注:需要先安装Java环境才能运行BFG。
请注意:Windows系统默认不安装Java环境,请自行安装Java环境并配置环境变量!
使用任意下载器下载文件:
1https://repo1.maven.org/maven2/com/madgag/bfg/1.13.0/bfg-1.13.0.jar
使用cmd,并切换到下载目录,执行如下命令使用BFG:
1java -jar bfg-1.13.0.jar [命令]
将你的Git项目Clone到本地:
1git clone https://github.com/AdlerED/Slog4J.git
将后面的项目地址修改为你自己的项目地址。
现在,进入到项目的根目录,并执行
1bfg --delete-files Tester.java --no-blob-protection
其中:
Tester.java 是我要彻底抹除痕迹的文件名,不需要也不能填写目录,bfg会删除该文件名的所有痕迹;
--no-blob-protection bfg默认不会删除当前分支下的文件,如需删除,须添加本参数;
--delete-files 代表删除指定文件,将其替换为**--delete-folders**可以删除指定文件夹。
还没结束,BFG并没有删除原文件,只是删除了.git中的所有记录,你需要手动去删除这个文件。删除后,你就可以重新将该项目Commit并Push到Github了:
1git commit --no-verify
2git push -u origin master --force
至此,你的错误已经被“抹去”了,但也要顺便提醒一下:
代码千万条,
安全第一条。
测试不规范,
老板两行泪。
此内容由惯性聚合(RSS阅读器)自动聚合整理,仅供阅读参考。 原文来自 — 版权归原作者所有。