推送Fork后的本地仓库至GitHub时遇权限拒绝错误求助
解决 Fork 仓库推送 Permission Denied 的问题
这个问题我碰到过好多次,核心原因要么是你的本地仓库还连着原作者的仓库(你没权限写进去),要么是认证环节出了问题。咱们一步步排查解决:
第一步:先确认本地仓库的远程地址
首先打开控制台,输入命令查看当前仓库关联的远程地址:
git remote -v
如果输出里的origin是原仓库(比如第一个账号的https://github.com/first-username/gitname.git),那问题就找到了——你试图推送到原作者的仓库,但你没有写权限,肯定会被拒绝。
第二步:把远程地址改成你自己 Fork 的仓库
如果上面的检查发现地址不对,用下面的命令替换成你第二个账号下的 Fork 仓库地址(比如https://github.com/second-username/gitname.git):
git remote set-url origin https://github.com/second-username/gitname.git
替换完之后再用git remote -v确认一下,确保origin指向的是你自己的仓库。
第三步:如果地址是对的,检查认证问题
如果远程地址已经是你自己的仓库,但还是报错,那大概率是认证出问题了:
- 如果你用的是 HTTPS 方式:现在 GitHub 已经不支持密码登录,得用**个人访问令牌(PAT)**代替密码。你可以在第二个账号的 GitHub 设置里生成一个 PAT,推送时输入用户名,密码栏填这个 PAT。
- 如果你用的是 SSH 方式:检查你的本地 SSH 密钥是不是关联到了第二个账号?每个 GitHub 账号需要对应独立的 SSH 密钥,如果你之前用的是第一个账号的密钥,第二个账号肯定认不出来。可以生成新的 SSH 密钥,然后添加到第二个账号的 SSH 设置里。
最后,重新尝试推送
做完上面的调整后,再执行推送命令:
git push origin master
(如果你的分支不是master,换成对应的分支名,比如main)
内容的提问来源于stack exchange,提问作者jundev




