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

  • Post author:
  • Post category:其他




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-SHA1

    key
在 ~/.ssh/config 加上如下配置
Host gitee.com 
HostkeyAlgorithms +ssh-rsa 
PubkeyAcceptedAlgorithms +ssh-rsa

PS:这种方式不需要更换ssh key,推荐

Linux



windows 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

的支持,

详情



版权声明:本文为weixin_42281031原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。