lin
2024-04-10 2d37fa5cf4ebf8bdcae40c5a9f63d561f307e2af
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
package org.springblade.es.test;
 
import org.apache.commons.lang3.StringUtils;
import org.apache.http.HttpHost;
import org.elasticsearch.action.admin.indices.refresh.RefreshRequest;
import org.elasticsearch.client.RestHighLevelClient;
import org.elasticsearch.client.RequestOptions;
import org.elasticsearch.client.RestClient;
import org.elasticsearch.client.RestClientBuilder;
import org.elasticsearch.action.index.IndexRequest;
import org.elasticsearch.action.index.IndexResponse;
import org.elasticsearch.action.search.SearchRequest;
import org.elasticsearch.action.search.SearchResponse;
import org.elasticsearch.index.query.QueryBuilders;
import org.elasticsearch.search.builder.SearchSourceBuilder;
import org.elasticsearch.search.SearchHit;
import org.elasticsearch.search.SearchHits;
 
import java.io.IOException;
import java.util.Map;
 
public class ElasticSearchExample {
 
    public static void main(String[] args) throws IOException {
        // 初始化Elasticsearch客户端
        RestClientBuilder builder = RestClient.builder(new HttpHost("localhost", 9200, "http"));
        RestHighLevelClient client = new RestHighLevelClient(builder);
 
        // 索引用户数据
        IndexRequest userIndexRequest = new IndexRequest("users_articles");
        userIndexRequest.source("name", "John Doe", "type", "user");
        IndexResponse userIndexResponse = client.index(userIndexRequest, RequestOptions.DEFAULT);
 
        // 索引文章数据
        IndexRequest articleIndexRequest = new IndexRequest("users_articles");
        articleIndexRequest.source("title", "Elasticsearch Introduction", "type", "article");
        IndexResponse articleIndexResponse = client.index(articleIndexRequest, RequestOptions.DEFAULT);
 
        // 刷新索引,确保文档可搜索
        client.indices().refresh(new RefreshRequest("users_articles"), RequestOptions.DEFAULT);
 
        // 全文搜索
        SearchRequest searchRequest = new SearchRequest("users_articles");
        SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
        searchSourceBuilder.query(QueryBuilders.multiMatchQuery("Elasticsearch", "name", "title"));
 
        //设置分页
        searchSourceBuilder.size(10);
        searchSourceBuilder.from(0);
 
        //将搜索资源对象设置到搜索客户端中
        searchRequest.source(searchSourceBuilder);
        //查询
        SearchResponse searchResponse = client.search(searchRequest, RequestOptions.DEFAULT);
        //解析搜索返回值
        SearchHits searchHits = searchResponse.getHits();
        //查询的总数
        long count = searchHits.getTotalHits().value;
 
        for (SearchHit hit : searchHits) {
            Map<String, Object> result = hit.getSourceAsMap();
            // 根据类型处理结果
            String type = (String) result.get("type");
            if ("user".equals(type)) {
                // 处理用户名
                String name = (String) result.get("name");
                System.out.println("User: " + name);
            } else if ("article".equals(type)) {
                // 处理文章标题
                String title = (String) result.get("title");
                System.out.println("Article: " + title);
            }
        }
 
        // 关闭客户端
        client.close();
    }
 
    /**
     * 设置高亮
     * @param keywords
     * @param info
     * @return
     */
    public static String setHighLight(String keywords, String info) {
        if (StringUtils.isBlank(keywords)|| StringUtils.isBlank(info)) {
            return info;
        }
        String[] keywordArray = keywords.split(" ");
        String newInfo = info;
        for (String keyword : keywordArray) {
            newInfo = newInfo.replace(keyword, "<em style=\"color:red\">" + keyword + "</em>");
        }
        return newInfo;
    }
}