java以SSL方式连ES

先做准备工作,浏览器方式访问 ES7.X url https://127.0.0.1:8027 弹出用户名和密码

输入后在浏览器得到

{

"name" : "DTCNPEMS04",

"cluster_name" : "cnp-es-cluster",

"cluster_uuid" : "wb0So_FqQBOKqtXnsqofTg",

"version" : {

"number" : "7.14.1",

"build_flavor" : "default",

"build_type" : "docker",

"build_hash" : "66b55ebfa59c92c15db3f69a335d500018b3331e",

"build_date" : "2021-08-26T09:01:05.390870785Z",

"build_snapshot" : false,

"lucene_version" : "8.9.0",

"minimum_wire_compatibility_version" : "6.8.0",

"minimum_index_compatibility_version" : "6.0.0-beta1"

},

"tagline" : "You Know, for Search"

}

说明浏览器可以获得SSL证书,然后用户可以按用户名/密码访问

后续思路就是从浏览器导出证书(略过),导入到JDK的security目录下,然后在代码里调用嵌入用户名和密码,SSL访问即可。

1) 假设浏览器导出证书为

2) 将证书转换为cer格式

openssl x509 -outform der -in es-devtest -out es-devtest.cer

3) 将证书导入到JDK的security目录下

keytool -import -alias es-devtest -keystore $HOME/java/jdk-8u291-linux-x64/jdk1.8.0_291/jre/lib/security/cacerts -file es-devtest.cer -trustcacerts -storepass changeit

4) 代码

bash 复制代码
String username="elastic";
String password="123456789";

        CredentialsProvider credentialsProvider = new BasicCredentialsProvider();
        credentialsProvider.setCredentials(AuthScope.ANY, new UsernamePasswordCredentials(username, password));

        esClient = new RestHighLevelClient(
                RestClient.builder(HttpHost.create("https://127.0.0.1:8027"))
                        .setHttpClientConfigCallback(httpClientBuilder -> httpClientBuilder
                                .setDefaultCredentialsProvider(credentialsProvider))
        );

连接不报错,就是成功,之后可以操作索引

相关推荐
找不到、了22 分钟前
JDK8 HashMap红黑树退化为链表的机制解析
java·数据结构·链表
西洼工作室33 分钟前
掌握单元测试:提升软件质量的关键步骤
java·单元测试
喝养乐多长不高1 小时前
Spring Web MVC基础理论和使用
java·前端·后端·spring·mvc·springmvc
秀才恶霸1 小时前
02_JVM
java·jvm
xx155802862xx1 小时前
用Redisson实现库存扣减的方法
java·python
图梓灵1 小时前
JVM内存模型深度解剖:分代策略、元空间与GC调优实战
java·jvm·笔记
D_aniel_2 小时前
排序算法-希尔排序
java·算法·排序算法·希尔排序
越来越无动于衷2 小时前
JAVA多态——向上转型
java·开发语言
等个结果2 小时前
应用服务器Tomcat
java·tomcat
cooldream20092 小时前
有状态服务、无状态服务与Session机制详解
java·开发语言·系统架构师