直接贴代码:
Map<String, Object> map = new HashMap<String, Object>();
AjaxResultModel arm = new AjaxResultModel();
try {
List<String> searchTypeList = new ArrayList<String>();
SolrServer server = new HttpSolrServer(SearchUtils.SOLR_HTTP_SERVER_URL);
SolrQuery query = new SolrQuery(SearchConstants.SEARCH_KEY_ALL + keyWord);
HightLightUtils.getFilterQuery(prece, news, book, boat, knowledge, operate, selectType, query);
PagingInfo page = HightLightUtils.setPageAndHightLight(curPage, pageSize, keyWord, query);
List<SolrInforModel> list = new ArrayList<SolrInforModel>();
QueryResponse qResponse = server.query(query);
String lastWord = SolrDocUtils.checkSpellKey(query, qResponse);
SolrDocumentList docs = qResponse.getResults();
FacetField facetField = qResponse.getFacetField("root_info_type_id");
List<Count> counts = null;
if (facetField != null) {
counts = facetField.getValues();
}
for (SolrDocument doc : docs) {
SolrDocUtils.getSolrDocument(list, qResponse, doc);
}
SpringModelExtraUtils.ajaxMapModel(pageSize, map, searchTypeList, page, list, lastWord, docs, counts);
arm.setData(map);
arm.setStatus(AjaxResultModel.SUCCESS);
} catch (Exception e) {
arm.setStatus(AjaxResultModel.FAIL);
logger.error(Thread.currentThread().getStackTrace()[1].getClass(),
Thread.currentThread().getStackTrace()[1].getMethodName(), e.getMessage());
}
JsonUtils.objToJson(arm, response);
}
public static String getFilterQuery( String news, String book, String boat, String knowledge,
String selectType, SolrQuery query) {
String fq = "";
if (StringUtils.isNotBlank(news)) {
fq += news + ",";
}
if (StringUtils.isNotBlank(book)) {
fq += book + ",";
}
if (StringUtils.isNotBlank(boat)) {
fq += boat + ",";
}
if (StringUtils.isNotBlank(knowledge)) {
fq += knowledge + ",";
}
if (StringUtils.isNotBlank(selectType) && !"all".equals(selectType)) {
fq += selectType + ",";
}
if (StringUtils.isNotBlank(fq)) {
fq = fq.substring(0, fq.lastIndexOf(","));
query.addFilterQuery(SearchConstants.INFO_TYPE_KEY + fq);
}
return fq;
}
HightLightUtils
/**
* 设置分页高亮
*
* @param curPage
* @param pageSize
* @param keyWord
* @param query
* @return
*/
public static PagingInfo setPageAndHightLight(Integer curPage, Integer pageSize, String keyWord, SolrQuery query) {
PagingInfo page = new PagingInfo(pageSize, curPage);
query.setStart((page.getCurrentPage() - 1) * page.getPageSize());
query.setRows(pageSize);
query.setHighlight(true);
query.setParam("hl.fl", "info_title,info_content");
query.setHighlightSimplePre("<font color=\'red\'>");
query.setHighlightSimplePost("</font>");
query.setHighlightFragsize(200);
query.set("qt", "/spell");
query.set("spellcheck", "on");
query.set("spellcheck.q", keyWord);
query.set("spellcheck.collate", "true");
query.set("spellcheck.dictionary", "file");
query.set("spellcheck.build", "true");
query.set("facet", "on");
query.set("facet.field", "root_info_type_id");
return page;
}
//纠错拼写
public static String checkSpellKey(SolrQuery query, QueryResponse spellRespose) throws SolrServerException {
String lastWord = "";
SpellCheckResponse spellCheckResponse = spellRespose.getSpellCheckResponse();
List<Suggestion> suggestionList = spellCheckResponse.getSuggestions();
if (suggestionList.size() > 0) {
if (!spellCheckResponse.isCorrectlySpelled()) {
lastWord = suggestionList.get(0).getAlternatives().toString().replace("[", "").replace("]", "");
if (lastWord.indexOf(",") > 0) {
lastWord = lastWord.split(",")[0].toString();
}
}
query.set("q", lastWord);
}
return lastWord;
}
//文档高亮等
public static String getSolrDocument(List<SolrInforModel> list, QueryResponse qResponse, SolrDocument doc) {
SolrInforModel pj = new SolrInforModel();
String id = doc.getFieldValue("id").toString();
String solrTitle = SolrStringUtils.htmlReplace(doc.getFieldValue("info_title").toString());
String solrType = SolrStringUtils.htmlReplace(doc.getFieldValue("info_type_name").toString());
pj.setId(id);
String hightTitle = qResponse.getHighlighting().get(id).get("info_title") == null ? solrTitle : SolrStringUtils
.htmlReplace(qResponse.getHighlighting().get(id).get("info_title").toString());
String solrContent = SolrStringUtils.htmlReplace(doc.getFieldValue("info_content").toString());
pj.setInfoContent(qResponse.getHighlighting().get(id).get("info_content") == null ? solrContent
: SolrStringUtils.htmlReplace(qResponse.getHighlighting().get(id).get("info_content").toString()));
pj.setInfoTitle(hightTitle);
pj.setInfoTypeName(solrType);
list.add(pj);
return solrType;
}
分享到:
相关推荐
这表明Solr设计为分布式、可扩展的解决方案,适合处理大量数据的全文检索、拼写检查、高亮显示、 faceted search(分面搜索)等任务。Solrj则作为与Solr服务器通信的桥梁,简化了这些操作的实现。 Solrj的主要功能...
SolrJ是Apache Solr官方提供的Java客户端库,它允许开发人员方便地与Solr服务器进行交互,包括索引数据、执行查询、处理结果等操作。下面将详细介绍这个示例代码可能涉及的几个关键知识点。 1. **Apache Solr**:...
DEMO将展示如何构造查询请求,包括基本查询、布尔运算、范围查询、高亮显示等。同时,结果处理如排序、分页、 faceting(分类统计)等也是查询的重要组成部分。 五、分布式Solr 随着数据量的增长,单个Solr实例可能...
SolrJ是Apache Solr官方提供的Java客户端库,主要用于与Solr服务器进行交互,包括索引数据、查询、管理Solr核心等操作。这个库极大地简化了开发人员在Java环境中与Solr通信的过程,使得我们可以方便地在应用程序中...
Solr查询与索引是Apache Solr的核心功能,它是一个基于Lucene的开源搜索引擎服务器,提供了高效、可扩展的全文检索、命中高亮、 faceted search(分面搜索)、拼写检查、动态集群等特性。在本文中,我们将深入探讨...
3. **查询与搜索**:展示如何使用Solrj发送查询请求,解析结果,并进行结果排序、分页和高亮显示。同时,会讨论查询优化策略,如使用过滤器、缓存和查询分析器等。 4. **高级功能**:可能包括实时索引更新、分布式...
5. 高亮查询 6. Suggest查询 7. SolrJ 章节三:Solr高级(上) 1. Solr Cloud 2. 函数查询 3. 地理位置查询 4. JSON Facet 章节四:Solr高级(下) 1. 深度分页 2. Solr Join查询 3. 相关度排序 4.Solr缓存 5....
查询结果可以自定义排序、分页和高亮显示,提升用户体验。 6. **分布式搜索** SolrCloud模式下,Solr支持分布式搜索。多台Solr服务器通过ZooKeeper协调,形成一个分布式集群。数据分布和查询路由由ZooKeeper自动...
除了基本功能,Solr还可以实现如拼音搜索、同义词扩展、高亮显示搜索结果、相关性评分等高级特性,进一步提升用户体验。例如,通过添加拼音分析器,用户可以用汉字拼音进行搜索;利用Solr的自定义相似度函数,可以...
在实际应用中,你还需要考虑性能优化,如使用Solr的缓存机制、分页查询、查询过滤器(Filter Queries)等。同时,为了确保高可用性和可扩展性,可能需要在生产环境中部署分布式Solr集群,利用ZooKeeper进行集群管理...
搜索功能可能还需要支持分页、高亮、过滤、排序等多种高级特性。 总的来说,Solr 在 TaoTao 项目中扮演了关键角色,提高了搜索效率和用户体验。理解 Solr 的核心概念、安装配置和使用方法,对于成功集成到电商项目...
2. **查询与结果处理**:展示如何构造查询语句,使用高亮、 faceting、自定义排序和分页等功能。 3. **搜索性能优化**:可能包含关于索引结构优化、查询缓存配置和硬件需求等方面的示例。 4. **分布式搜索**:在...
7、通过Solr后台管理界面对索引进行CRUD高亮过滤排序分页 8、通过Solrj实现索引的添加更新 9、通过Solrj实现索引的删除 10、索引的检索_过滤_高亮等操作 11、项目实战应用 12、Solr知识点总结 1、熟练掌握...
8、通过Solr后台管理界面对索引进行CRUD高亮过滤排序分页 9、通过Solrj实现索引的添加更新 10、通过Solrj实现索引的删除 11、索引的检索_过滤_高亮等操作 12、项目实战应用 13、Solr知识点总结 14、ElasticSearch...