如何在Solr中高亮显示文本?

5

我刚接触Solr,使用的版本是4.3.0。我只想启用基本的高亮显示功能。我已经创建了一个使用AJAX-Solr的UI,并且正在使用默认的请求处理程序。 请从头开始指导我。同时,我希望通过请求处理程序启用高亮显示,而不是通过查询URL参数来实现。 提前致谢。

3个回答

4

您可以通过传递高亮参数直接测试高亮功能。

例如:hl=true&hl.fl=name,features

此外,您还可以在solrconfig.xml中的请求处理程序中配置默认的高亮设置,例如:

<requestHandler name="/browse" class="solr.SearchHandler">
 <lst name="defaults">

    ................

   <!-- Highlighting defaults -->
   <str name="hl">on</str>
   <str name="hl.fl">content features title name</str>
   <str name="hl.encoder">html</str>
   <str name="hl.simple.pre">&lt;b&gt;</str>
   <str name="hl.simple.post">&lt;/b&gt;</str>
   <str name="f.title.hl.fragsize">0</str>
   <str name="f.title.hl.alternateField">title</str>
   <str name="f.name.hl.fragsize">0</str>
   <str name="f.name.hl.alternateField">name</str>
   <str name="f.content.hl.snippets">3</str>
   <str name="f.content.hl.fragsize">200</str>
   <str name="f.content.hl.alternateField">content</str>
   <str name="f.content.hl.maxAlternateFieldLength">750</str>


 </lst>

</requestHandler>

你好,我按照你的建议进行了更改,但是高亮功能仍然无法正常工作。 - Archit Arora
我已经将solr与ajax-solr集成,以帮助创建用户界面。在ajax solr中,Manager.response.highlighting反映了突出显示的内容。我按照你建议的在solrconfig.xml中进行了更改,但是Manager.response.highlighting没有显示任何结果。请问可以指导我如何从头开始启用此功能吗?我正在使用默认的/search处理程序。我需要在那里启用一些东西吗?谢谢。 - Archit Arora

4
如果您正在使用Ajax-solr,则不需要使用Solr服务器的高亮参数。
Solr-Ajax将使用facet component创建一个JavaScript列表,其中包含您键入的匹配单词。
换句话说,如果您正在使用ajax-solr,您需要修改AutocompleteWidget.js。
您需要从第23行到33行修改原始autocomplete reuters example
并用这个部分代码替换它。
$(self.target).find('input').autocomplete('destroy').autocomplete({
        source: function( request, response ) {

            var srchTerm = request.term.split(/\s+/).join ('|');
            var matcher = new RegExp( "(" + AjaxSolr.Parameter.escapeValue( srchTerm )+")", "ig" );
            response( $.grep( list, function( item ){
                return matcher.test( item.value );
            }) );
        },
        select: function(event, ui) {        
          if (ui.item) {
            self.requestSent = true;
            if (self.manager.store.addByValue('fq', ui.item.field + ':' + AjaxSolr.Parameter.escapeValue(ui.item.value))) {
              self.doRequest();
            }
          }
        }
      }).data('autocomplete')._renderItem = function( ul, item ) {

          var srchTerm = this.term.trim().split(/\s+/).join ('|');          
          var strNewLabel = item.label;         

          regexp = new RegExp ('(' + srchTerm + ')', "ig");          
          var strNewLabel = strNewLabel.replace(regexp,"<span style='font-weight:bold;color:#880010;'>$1</span>");

          return $( "<li></li>" )
            .data( "item.autocomplete", item )
            .append( "<a>" + strNewLabel + ' (' +  item.counter + ') ' + "</a>" )
        .appendTo( ul );
 };

这是我在项目中使用的完整文件
(function (callback) {
  if (typeof define === 'function' && define.amd) {
  define(['../core/AbstractTextWidget'], callback);
  }
  else {
   callback();
  }
}(function () {

(function ($) {

AjaxSolr.AutocompleteWidget = AjaxSolr.AbstractTextWidget.extend({
  afterRequest: function () {
    $(this.target).find('input').unbind().removeData('events').val('');

    var self = this;

    var callback = function (response) {
      var list = [];
      for (var i = 0; i < self.fields.length; i++) {
        var field = self.fields[i];
        for (var facet in response.facet_counts.facet_fields[field]) {          
          list.push({
            field: field,
            counter: response.facet_counts.facet_fields[field][facet], 
            value: facet,
            label: facet 
          });
        }
      }

      self.requestSent = false;
      $(self.target).find('input').autocomplete('destroy').autocomplete({
        source: function( request, response ) {

            var srchTerm = request.term.split(/\s+/).join ('|');
        var matcher = new RegExp( "(" + AjaxSolr.Parameter.escapeValue( srchTerm )+")", "ig" );
        response( $.grep( list, function( item ){
            return matcher.test( item.value );
        }) );
    },
    select: function(event, ui) {        
      if (ui.item) {
        self.requestSent = true;
        if (self.manager.store.addByValue('fq', ui.item.field + ':' + AjaxSolr.Parameter.escapeValue(ui.item.value))) {
              self.doRequest();
            }
          }
        }
      }).data('autocomplete')._renderItem = function( ul, item ) {

          var srchTerm = this.term.trim().split(/\s+/).join ('|');          
          var strNewLabel = item.label;         

          regexp = new RegExp ('(' + srchTerm + ')', "ig");          
          var strNewLabel = strNewLabel.replace(regexp,"<span style='font-weight:bold;color:#880010;'>$1</span>");

          return $( "<li></li>" )
            .data( "item.autocomplete", item ).append( "<a>" + strNewLabel + ' (' +  item.counter + ') ' + "</a>" )
        .appendTo( ul );
     };

      // This has lower priority so that requestSent is set.
      $(self.target).find('input').bind('keydown', function(e) {          
        if (self.requestSent === false && e.which == 13) {
          var value = $(this).val();
          if (value && self.set(value)) {
            self.doRequest();
          }
        }
      });
    } // end callback

    var params = [ 'rows=0&facet=true&facet.limit=30&facet.mincount=1&json.nl=map&hl=true&hl.q='+this.manager.store.get('q').val() ];
    var hightLithing='&hl.fl=';
    for (var i = 0; i < this.fields.length; i++) {
      params.push('facet.field=' + this.fields[i]);
      hightLithing = hightLithing + this.fields[i]+',';
    }
    hightLithing.slice(0,-1);
    params.push(hightLithing);
    var values = this.manager.store.values('fq');    
    for (var i = 0; i < values.length; i++) {
      params.push('fq=' + encodeURIComponent(values[i]));      
    }
    params.push('q=' + this.manager.store.get('q').val());
    $.getJSON(this.manager.solrUrl + 'select?' + params.join('&') + '&wt=json&json.wrf=?', {}, callback);
  }//end afterRequest
});

})(jQuery);

}));

0

我没有看到任何名为solr.xml的文件。它应该是solrconfig.xml吗? - fanchyna

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接