提交项目代码时不小心把敏感文件提交到了远程仓库。即使删除了文件,git还是保留了提交日志。
例如,需要删除key.txt的提交记录
1.删除本地记录
git filter-branch --force --index-filter 'git rm --cached --ignore-unmatch key.txt' --prune-empty --tag-name-filter cat -- --all
2.提交代码时排除key.txt
echo key.txt >> .gitignore git add .gitignore git commit -m "提交时忽略key.txt"
3.提交到远程仓库
git push origin --force --all
如果tag中也需要删除敏感数据,则执行
git push origin --force --tags
再查看远程提交记录,发现之前的提交记录已经被删除了。
注意: 如果其他用户已经拉取了key.txt文件,需要他们rebase 之前拉取的仓库, 不要merge, 因为merge后提交,会把之前清除的敏感文件又提交到仓库里。