java - Grpc Java 客户端的 SSL 连接

标签 java ssl netty grpc grpc-java

我正在尝试通过 GRPC-SSL 将 Java 客户端连接到非 Java 服务器。我可以在不使用 SSL 时连接到服务器。当我尝试使用 SSL 上下文(使用提供的 pem 文件)创建 ManagedChannel 时,出现以下异常(相同的 pem 文件适用于 NodeJS 客户端)。

ManagedChannel channel = NettyChannelBuilder.forAddress("localhost", 10010)
    .sslContext(GrpcSslContexts.forClient().trustManager(new File("./test/myprivkey.pem")).build())
    .build();

trustManager 调用异常:

Exception in thread "main" java.lang.IllegalArgumentException: File does not contain valid certificates: /Users/continue/IdeaProjects/git/test/build/resources/main/keys/myprivkey.pem
    at io.netty.handler.ssl.SslContextBuilder.trustManager(SslContextBuilder.java:162)
    at com.test.io.grpc.test.client.Connection.getSslContext(Connection.java:65)
    at com.test.io.grpc.test.client.Connection.getSecure(Connection.java:41)
    at com.test.io.grpc.mgcs.client.TestClient.<init>(TestClient.java:36)
    at com.test.io.grpc.test.client.TestClient.main(TestClient.java:89)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)
    at com.intellij.rt.execution.application.AppMain.main(AppMain.java:147)
Caused by: java.security.cert.CertificateException: found no certificates in input stream
    at io.netty.handler.ssl.PemReader.readCertificates(PemReader.java:98)
    at io.netty.handler.ssl.PemReader.readCertificates(PemReader.java:64)
    at io.netty.handler.ssl.SslContext.toX509Certificates(SslContext.java:999)
    at io.netty.handler.ssl.SslContextBuilder.trustManager(SslContextBuilder.java:160)

build.gradle相关部分

compile 'io.netty:netty-tcnative-boringssl-static:1.1.33.Fork26'

任何想法可能导致问题或如何进一步解决此问题?

最佳答案

我读错了文件作为构建 SslContext 的证书文件。用正确的证书文件替换不正确的输入解决了这个问题。

关于java - Grpc Java 客户端的 SSL 连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42700411/

相关文章:

java - 从java中的嵌套对象列表中按id查找对象

ssl - Heroku SSL 重定向错误

cordova - 无法使用 cordova iOS 在 iframe 中正确加载外部 URL

ssl - 库伯内斯 1.2.2 : api-server fails: can't find mounted certs for TLS on etcd

http - Netty - 通过 ssl 发送 http 请求

sockets - 触发按需 TCP 消息到可重新连接、不可共享的 Netty 管道的正确方法是什么?

java - 游戏循环-线程

java - Reactor Flux 上的条件逻辑

Java - 为什么HashMap中的hash和key是最终的

java - Netty 将 HttpRequest 转换为 ByteBuf