突然拉不下來項目,重復生成、設置多次SSH都沒用
Permission denied (publickey)
嘗試了很多博客的方法都沒用。最后還是在gitee官網找到問題、解決辦法。
出現的問題
2021年09月26日發布的OpenSSH 8.8
中移除了對RSA-SHA1的支持
- 最新的
git for windows 2.33.1
版本已使用OpenSSH 8.8
- arch和manjaro等發行版的滾動升級比較激進,使用
pacman -Syu
就會升級所有軟件到最新版本- 此時的表現就是之前還可以正常使用,
pacman -Syu
或升級到git for windows 2.33.1
之后使用git pull
就出現fatal: 無法讀取遠程倉庫
的提示
如果您升級到OpenSSH 8.8
或以上版本,則使用ssh推拉Gitee代碼時會出現校驗不通過的問題
原因
我們使用golang.org/x/crypto/ssh
來從public key中提取出指紋,以此從Gitee主應用兌換用戶信息
而這個庫目前(2021-10-12)還沒有支持RSA-SHA2
算法,因此會獲取不到指紋,導致用戶校驗失敗
臨時解決
下述三種方案任選其一即可
- 配置OpenSSH服務允許使用
RSA-SHA1
key
在 ~/.ssh/config 加上如下配置 Host gitee.com HostkeyAlgorithms +ssh-rsa PubkeyAcceptedAlgorithms +ssh-rsa
PS:這種方式不需要更換ssh key,推薦
Linux
和windows git bash
用戶使用
- 換用其他算法生成ssh key
ssh-keygen -t ed25519 -C "your@example.email" 之后到Gitee重新添加公鑰即可
PS: 這種方式需要更換ssh key,推薦
windows
用戶使用
- 暫時不要使用
OpenSSH 8.8
及以上版本