Spring Cloud Config下reject HostKey: gitee.com问题,及You‘re using an RSA key withSHA-1问题的解决

 解决思路如下:

1 修改rsa加密方式,操作步骤如下:

--进入当前用户的home目录
--删除.ssh 目录
$ rm -rvf .ssh

--如果要使用SpringCloudConfig的免密登录,则使用如下命令生成秘钥和公钥
ssh-keygen -m PEM -t rsa -b 4096 -f -C a7810222@qq.com

如果是windows系统,则会在如下图位置生成id_rsa,id_rsa.pub,后两个文件是第一次使用git clone + git地址后自动产生的文件,如果要在SpringCloudConfig中使用默认的系统配置,则需要先git clone一下:

然后需要在gitee或github上配置公钥,具体配置可以参考Git进阶系列2. Gitee以及Github使用详细教程_每天都要努力的小颓废呀的博客-CSDN博客

之后可能会出现spring cloud ERROR: You're using an RSA key with SHA-1, which is no longer allowed. Please use a newer client问题,因为Spring Cloud Config Server使用org.eclipse.jgit库进行git操作,这里的问题是,该库的版本较久,不支持较新版本的RSA密钥(sha2-256 / sha2-512)。

com.jcraft.jsch有一个分支,实现了Github接受的较新版本的RSA,下面是我做的改动。

对pom.xml进行修改:

      <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-config-server</artifactId>
                <!-- 不引入这个较旧的、没有维护的库,因为该版本不支持较新版本的RSA加密 -->
            <exclusions>
                <exclusion>
                    <groupId>com.jcraft</groupId>
                    <artifactId>jsch</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
<!--        该版本支持较新版本的RSA(sha2-256 / sha2-512) -->
        <dependency>
            <groupId>com.github.mwiede</groupId>
            <artifactId>jsch</artifactId>
            <version>0.2.0</version>
        </dependency>

 还得添加一个shim配置类来解决这个问题:

package com.hashnode.config;

import com.jcraft.jsch.JSch;
import org.springframework.context.annotation.Configuration;

@Configuration
public class JschConfig {
    //Shim to fix the way jGit configures JSch
    static{
        JSch.setConfig("signature.rsa", "com.jcraft.jsch.jce.SignatureRSA");
    }

}

对applicaiton.yml做如下配置:

server:
  port: 3344

spring:
  application:
    name:  cloud-config-center #注册进Eureka服务器的微服务名
  cloud:
    config:
      server:
        git:
#          以下两步均需要在idea的插件中配置gitee
          # 方式1 通过ssh登录
#          uri: git@github.com:GuoWeiChi/turorial-spring-cloud-config.git #GitHub上面的git仓库名字
          uri: git@gitee.com:codinginn/turorial-spring-cloud-config.git #Gitee上面的git仓库名字
          #          ###搜索目录
          search-paths:
            - turorial-spring-cloud-config
          # 方式2 通过账号登录
#          uri: https://gitee.com/codinginn/turorial-spring-cloud-config.git 
#          search-paths:
#            - turorial-spring-cloud-config
#          username: 你自己的登录用户名
#          password: 登录密码

####读取分支
        label: master



然后即可运行项目,完成访问:

评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

潮浪之巅

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值