错误场景与原因
由于之前注册了一个新的git账号并且保留在VScode上,最近在常用的旧git账号上建了一个仓库。没有意识到VScode上登录的是另一个账号。我照常拉取仓库更改代码提交到仓库,结果就是没有权限并在新账号的远程仓库中建了一个新仓库并创建了提交。
这不是我想要的效果,我还是想在旧账号中更新仓库。
首先说一下为啥会存在这种情况,后续在记录我具体的解决过程(走弯路过程)。
Git 会缓存你输入的用户名和密码(或 token),即使你已经切换了账户,缓存的凭证仍然会用于认证。如果旧账户的凭证还在缓存中,Git 会继续使用旧账户信息进行推送。
控制面板->凭据管理查看
弯路过程
首先我删除本地仓库相关文件,并且切换VScode中登录的账号。重新拉取仓库,并在旧账号的操作下更新代码提交、推送。但是依然存在下面情况,与之前的新账号操作一样的提示(因为上面提到的原因):
接下来就是解决过程了:
-
通过命令
git remote -v
查看当前关联的远程仓库
-
git config user.name
和git config user.email
获取的git账号信息都与旧账号保持一致 -
ssh -T git@github.com
查看当前权限,是被拒绝的…
说明 SSH 认证仍然使用的是之前的 GitHub 账号的 SSH 密钥(后续操作时发现我的github没有进行ssh认证,使用的是https) -
对ssh认证进行配置,在Git Bash中生成密钥,复制公钥提供给GitHub
eval "$(ssh-agent -s)" # 启动SSH代理
ssh-keygen -t rsa -b 4096 -C "email.com" # 生成新的SSH密钥
ssh-add ~/.ssh/id_rsa # 将生成的私钥添加到SSH代理
cat ~/.ssh/id_rsa.pub # 获取公钥内容,并复制
复制公钥后,进入GitHub->SSH and GPG Keys->New SSH key. 新增 new key 将复制的公钥添加进去
ssh -T git@github.com # 验证是否认证成功
显示下面内容表示成功:
Hi XXX! You've successfully authenticated, but GitHub does not provide shell access.
到这一步认证成功了!但是我推送依然没有成功,原因有两个:(1)仓库推送的时候使用的HTTPS进行通信;(2)git使用缓存中的旧凭证进行验证
(因为这时候我还没发现缓存旧凭证这回事)
- 将仓库https改为ssh认证
https下我们通过git remote -v
看到的仓库格式如下,是包含https
的
origin https://github.com/***/repo_name.git (fetch)
origin https://github.com/***/repo_name.git (push)
通过下面命令修改格式:
git remote set-url origin git@github.com:***/仓库名.git
这就可以推送啦!