gpt4 book ai didi

rest - SSLPeerUnverifiedException - <> 的证书与证书主体的通用名称不匹配

转载 作者:行者123 更新时间:2023-12-02 20:36:27 27 4
gpt4 key购买 nike

当我们尝试从 zuul 访问安全 https REST 点时,出现以下异常。

2017-10-27 08:26:08.499 DEBUG 15708 --- [http-nio-9092-exec-1] o.a.h.c.ssl.SSLConnectionSocketFactory   : Secure session established2017-10-27 08:26:08.500 DEBUG 15708 --- [http-nio-9092-exec-1] o.a.h.c.ssl.SSLConnectionSocketFactory   :  negotiated protocol: TLSv1.22017-10-27 08:26:08.500 DEBUG 15708 --- [http-nio-9092-exec-1] o.a.h.c.ssl.SSLConnectionSocketFactory   :  negotiated cipher suite: TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA2562017-10-27 08:26:08.501 DEBUG 15708 --- [http-nio-9092-exec-1] o.a.h.c.ssl.SSLConnectionSocketFactory   :  peer principal: CN=10.xxx.xx.xx, OU=xxx, O=xxx, L=xxx, ST=xx, C=xx2017-10-27 08:26:08.502 DEBUG 15708 --- [http-nio-9092-exec-1] o.a.h.c.ssl.SSLConnectionSocketFactory   :  issuer principal: CN=10.xxx.xx.xx, OU=xxx, O=xxx, L=xxx, ST=xx, C=xx2017-10-27 08:26:08.516 DEBUG 15708 --- [http-nio-9092-exec-1] o.a.h.conn.ssl.DefaultHostnameVerifier   : Certificate for  doesn't match common name of the certificate subject: 10.xxx.xx.xxjavax.net.ssl.SSLPeerUnverifiedException: Certificate for  doesn't match common name of the certificate subject    at org.apache.http.conn.ssl.DefaultHostnameVerifier.matchCN(DefaultHostnameVerifier.java:186)    at org.apache.http.conn.ssl.DefaultHostnameVerifier.verify(DefaultHostnameVerifier.java:133)    at org.apache.http.conn.ssl.DefaultHostnameVerifier.verify(DefaultHostnameVerifier.java:99)    at org.apache.http.conn.ssl.SSLConnectionSocketFactory.verifyHostname(SSLConnectionSocketFactory.java:463)    at org.apache.http.conn.ssl.SSLConnectionSocketFactory.createLayeredSocket(SSLConnectionSocketFactory.java:397)    at org.apache.http.conn.ssl.SSLConnectionSocketFactory.connectSocket(SSLConnectionSocketFactory.java:355)    at org.apache.http.impl.conn.DefaultHttpClientConnectionOperator.connect(DefaultHttpClientConnectionOperator.java:142)    at org.apache.http.impl.conn.PoolingHttpClientConnectionManager.connect(PoolingHttpClientConnectionManager.java:359)    at org.apache.http.impl.execchain.MainClientExec.establishRoute(MainClientExec.java:381)    at org.apache.http.impl.execchain.MainClientExec.execute(MainClientExec.java:237)    at org.apache.http.impl.execchain.ProtocolExec.execute(ProtocolExec.java:185)    at org.apache.http.impl.execchain.RetryExec.execute(RetryExec.java:89)    at org.apache.http.impl.execchain.RedirectExec.execute(RedirectExec.java:111)    at org.apache.http.impl.client.InternalHttpClient.doExecute(InternalHttpClient.java:185)    at org.apache.http.impl.client.CloseableHttpClient.execute(CloseableHttpClient.java:83)    at org.apache.http.impl.client.CloseableHttpClient.execute(CloseableHttpClient.java:108)    at org.apache.http.impl.client.CloseableHttpClient.execute(CloseableHttpClient.java:56)    at org.springframework.cloud.netflix.ribbon.apache.RibbonLoadBalancingHttpClient.execute(RibbonLoadBalancingHttpClient.java:94)    at org.springframework.cloud.netflix.ribbon.apache.RibbonLoadBalancingHttpClient.execute(RibbonLoadBalancingHttpClient.java:43)    at com.netflix.client.AbstractLoadBalancerAwareClient$1.call(AbstractLoadBalancerAwareClient.java:109)    at com.netflix.loadbalancer.reactive.LoadBalancerCommand$3$1.call(LoadBalancerCommand.java:303)    at com.netflix.loadbalancer.reactive.LoadBalancerCommand$3$1.call(LoadBalancerCommand.java:287)    at rx.internal.util.ScalarSynchronousObservable$3.call(ScalarSynchronousObservable.java:231)    at rx.internal.util.ScalarSynchronousObservable$3.call(ScalarSynchronousObservable.java:228)    at rx.Observable.unsafeSubscribe(Observable.java:10211)    at rx.internal.operators.OnSubscribeConcatMap$ConcatMapSubscriber.drain(OnSubscribeConcatMap.java:286)    at rx.internal.operators.OnSubscribeConcatMap$ConcatMapSubscriber.onNext(OnSubscribeConcatMap.java:144)    at com.netflix.loadbalancer.reactive.LoadBalancerCommand$1.call(LoadBalancerCommand.java:185)    at com.netflix.loadbalancer.reactive.LoadBalancerCommand$1.call(LoadBalancerCommand.java:180)...

服务通过 POST 请求向 eureka 注册。请查找以下示例 POST 请求。

    spring:      application:        name: gateway     server:      port: 9092      ssl:            enabled: true        clientAuth: want        key-store: classpath:keystore.jks        key-store-password: password        key-password: password           key-alias: xxxx    eureka:      instance:        nonSecurePortEnabled: false        securePortEnabled: true      client:        serviceUrl:          defaultZone: ${EUREKA_URI:http://localhost:8761/eureka}        registry-fetch-interval-seconds: 15        register-with-eureka: true        fetch-registry: true        heartbeat-executor-thread-pool-size: 5        eureka-service-url-poll-interval-seconds: 10    zuul:      prefix: /tree      routes:        serv:          path: /cxf/**          strip-prefix: false          serviceId: serv    ribbon:      IsSecure: true      IsHostnameValidationRequired: false

服务通过 POST 请求向 eureka 注册。请查找以下示例 POST 请求。

    {    "instance": {        "hostName": "xxx",        "app": "appname",        "vipAddress": "appname",        "secureVipAddress": "appname",        "ipAddr": "10.xxx.xx.xxx",        "status": "UP",        "port": {"$": "8181", "@enabled": "true"},        "securePort": {"$": "8443", "@enabled": "true"},        "healthCheckUrl": "http://localhost:8000/cat",        "statusPageUrl": "http://localhost:8000/cat",        "homePageUrl": "http://localhost:8000/cat",        "dataCenterInfo": {            "@class": "com.netflix.appinfo.InstanceInfo$DefaultDataCenterInfo",             "name": "MyOwn"        }    }

如果我将serviceId替换为上面zuul配置中相应的url,它就可以正常工作。

keystore.jks 已位于 src/main/resources 下。此外,还将 keystore 条目导入到 $JDK_HOME/jre/lib/security/cacerts 下的证书中。我们还缺少其他配置吗?

注意: REST 端点是 OSGI 服务。 Spring 启动版本:v1.5.7.RELEASE我们使用嵌入式tomcat。

最佳答案

出现上述问题的原因是证书不包含“SubjectAlternativeName”字段。使用字段“SubjectAlternativeName”创建证书后,该字段又包含 CN(通用名称)和 IP 详细信息,问题得到解决。我们还需要生成信任库

对于正在寻找解决方案的人,希望以下步骤可能有所帮助。

<强>1。生成服务器 key 和自签名服务器证书keytool -genkey -alias serverkey -keyalg RSA -storetype PKCS12 -keystore serverkeystore.p12 -ext SAN=dns:abc.com,dns:localhost,ip:127.0.0.1

<强>2。生成客户端 key 和自签名客户端证书keytool -genkey -alias clientkey -keyalg RSA -storetype PKCS12 -keystore clientkeystore.p12 -ext SAN=dns:def.com,dns:localhost,ip:127.0.0.1

<强>3。导出服务器证书keytool -export -alias serverkey -file servercert.cer -keystore serverkeystore.p12

<强>4。导出客户端证书keytool -export -alias clientkey -file clientcert.cer -keystore clientkeystore.p12

<强>5。将证书导入 $JAVA_HOME/jre/lib/securitysudo keytool -import -trustcacerts -alias localhost -file localhost.crt -keystore $JAVA_HOME/jre/lib/security/cacerts

网关的application.yml:

spring:
application:
name: gateway
server:
port: 8443
ssl:
enabled: true
key-store: classpath:serverkeystore.p12
key-store-password: server
key-alias: serverkey
eureka:
instance:
securePort: ${server.port}
nonSecurePortEnabled: false
securePortEnabled: true
leaseRenewalIntervalInSeconds: 7
leaseExpirationDurationInSeconds: 9
client:
serviceUrl:
defaultZone: ${EUREKA_URI:http://localhost.com:8761/eureka/}
registry-fetch-interval-seconds: 5
register-with-eureka: true
fetch-registry: true
heartbeat-executor-thread-pool-size: 5
eureka-service-url-poll-interval-seconds: 10
zuul:
prefix: /service
routes:
producer:
path: /employee/**
strip-prefix: false
serviceId: producer
ribbon:
IsSecure: true
logging:
file: logs/gateway.log
level.root: INFO
level.com.fujitsu.fnc.sdnfw.msvc: DEBUG

关于rest - SSLPeerUnverifiedException - <> 的证书与证书主体的通用名称不匹配,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46975707/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com