пользовательский QueryResponseWriter не работает в Solr 7.3.0 - PullRequest
0 голосов
/ 13 мая 2018

Я беру приручение текста книгу в качестве примера для добавления пользовательских QueryResponseWriter в solr. Но это не показано в wt как tah

Когда я нажимаю на следующий запрос, отображается пустой ответ

http://localhost:8983/solr/collectiona/type-ahead?q=fayes&wt=tah

В моей конфигурации solr я поместил следующий путь к каталогу моей библиотеки

<lib dir="${solr.install.dir:../../../..}/contrib/customresponsewriter" regex=".*\.jar" />

Я создал файл jar для этого, как упомянуто в книге. Вот мой класс Java

public class TypeAheadResponseWriter implements QueryResponseWriter {
        private Set<String> fields;


        public void write(Writer writer, SolrQueryRequest solrQueryRequest, SolrQueryResponse solrQueryResponse) throws IOException {
            SolrIndexSearcher searcher = solrQueryRequest.getSearcher();
            NamedList namedList = solrQueryResponse.getValues();
            int size = namedList.size();
            for (int i = 0; i < size; i++) {
                Object val = namedList.getVal(i);
                if (val instanceof DocList) {
                    DocList docList = (DocList) val;
                    DocIterator docIterator = docList.iterator();
                    writer.append("<ul>\n");
                    while (docIterator.hasNext()) {
                        int id = docIterator.nextDoc();
                        Document doc = searcher.doc(id, fields);
                        String name = doc.get("title");
                        writer.append("<li>" + name + "</li>");
                    }
                    writer.append("</ul>\n");
                }
            }
        }


        public String getContentType(SolrQueryRequest solrQueryRequest, SolrQueryResponse solrQueryResponse) {
            return "text/html;charset=UTF-8";
        }


        public void init(NamedList namedList) {
            fields = new HashSet<String>();
            fields.add("title");
        }
}

Вот мой конфиг solr для queryResponsewriter

<queryResponseWriter name="tah" class="cqw.TypeAheadResponseWriter"/>
   <requestHandler name="/type-ahead" class="solr.SearchHandler">
    <lst name="defaults">
     <str name="wt">tah</str>
     <str name="defType">dismax</str>
     <str name="qf">title_prefix_typeahead^1.0</str>
 </lst>
</requestHandler>

Пользовательская библиотека загружается во время запуска Solr, вот мой журнал Solr

Добавлено 63 библиотеки в загрузчик классов из путей: [/home/bibek/software/java/solr-7.3.0/contrib/clustering/lib, /home/bibek/software/java/solr-7.3.0/contrib / customresponsewriter, /home/bibek/software/java/solr-7.3.0/contrib/extraction/lib, /home/bibek/software/java/solr-7.3.0/contrib/langid/lib, / home / bibek / программное обеспечение / java / solr-7.3.0 / contrib / speed / lib, /home/bibek/software/java/solr-7.3.0/dist]

1 Ответ

0 голосов
/ 15 мая 2018

В solr-core 7.3 NameList::getVal(index) вернет BasicResultContext, что будет содержать DocList экземпляр. Вот мой измененный код ниже для дальнейшего использования

public void write(Writer writer, SolrQueryRequest solrQueryRequest, SolrQueryResponse solrQueryResponse) throws IOException {
    LOGGER.info("Here we are....");
    SolrIndexSearcher searcher = solrQueryRequest.getSearcher();
    NamedList namedList = solrQueryResponse.getValues();
    LOGGER.info("Named List " + namedList.size());
    int size = namedList.size();
    for (int i = 0; i < size; i++) {
        Object val = namedList.getVal(i);
        LOGGER.info(val.toString());
        if (val instanceof BasicResultContext) {
            BasicResultContext basicResultContext = (BasicResultContext) val;
            DocList docList = basicResultContext.getDocList();
            LOGGER.info("docList List " + docList.size());
            DocIterator docIterator = docList.iterator();
            writer.append("<ul>\n");
            while (docIterator.hasNext()) {
                int id = docIterator.nextDoc();
                LOGGER.info("id id " + id);
                Document doc = searcher.doc(id, fields);
                for (String field : fields) {
                    String value = doc.get(field);
                    LOGGER.info(value);
                    if (!StringUtils.isEmpty(value)) {
                        writer.append("<li>" + value + "</li>");
                    }
                }
            }
            writer.append("</ul>\n");
        }
    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...