微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

SSH Key 突然失效问题解答及处理办法 Permission denied (publickey)

突然拉不下来项目,重复生成、设置多次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算法,因此会获取不到指纹,导致用户校验失败

临时解决

下述三种方案任选其一即可

  1. 配置OpenSSH服务允许使用RSA-SHA1key
在 ~/.ssh/config 加上如下配置
Host gitee.com 
HostkeyAlgorithms +ssh-rsa 
PubkeyAcceptedAlgorithms +ssh-rsa

PS:这种方式不需要更换ssh key,推荐Linuxwindows git bash用户使用

  1. 换用其他算法生成ssh key
ssh-keygen -t ed25519 -C "your@example.email"
之后到Gitee重新添加公钥即可

PS: 这种方式需要更换ssh key,推荐windows用户使用

  1. 暂时不要使用OpenSSH 8.8及以上版本

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐