OpenSSH 8.8以上版本出现Permission denied(publickey)的问题 出现问题

OpenSSH 8.8以上版本出现Permission denied(publickey)的问题

出现问题

使用ssh拉取仓库代码时出现报错(确保自己正确配置了ssh)

  • gitlab报错

no matching host key type found. Their offer: ssh-rsa,ssh-dss

fatal: Could not read from remote repository.

Please make sure you have the correct access rights
and the repository exists.

  • gitee报错

Permission denied(publickey)

使用ssh -vvvT git@gitlab.com命令可查看到自己OpenSSH的版本

image-20211112141745758

原因

gitlab和gitee使用golang.org/x/crypto/ssh来从public key中提取出指纹,以此兑换用户信息

而这个库目前(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及以上版本

目前golang社区已经关注到了这一情况,且已经在推进对RSA-SHA2的支持,详情

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值