1.将下载的apache-solr-3.3.0.zip包进行解压。
2.将目录下example/solr中的文件拷到某一目录(solr.xml不能拷过去)。将此目录设为solr_home.并在tomcat的server.xml中加入如下内容:
<Context docBase="mvn_struts2" path="/mvn_struts2"
reloadable="true" source="org.eclipse.jst.jee.server:mvn_struts2">
<Environment name="solr/home" type="java.lang.String"
value="C:\Users\Kevin\Downloads\apache-solr-3.3.0\apache-solr-3.3.0\example\solr"
override="true" />
</Context>
3.在工程的web.xml中加入如下内容:
<filter>
<filter-name>SolrRequestFilter</filter-name>
<filter-class>org.apache.solr.servlet.SolrDispatchFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>SolrRequestFilter</filter-name>
<url-pattern>/lucene/*</url-pattern>
</filter-mapping>
<servlet>
<servlet-name>SolrServer</servlet-name>
<servlet-class>org.apache.solr.servlet.SolrServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet>
<servlet-name>SolrUpdate</servlet-name>
<servlet-class>org.apache.solr.servlet.SolrUpdateServlet</servlet-class>
<load-on-startup>2</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>SolrServer</servlet-name>
<url-pattern>/lucene/select/*</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>SolrUpdate</servlet-name>
<url-pattern>/lucene/update/*</url-pattern>
</servlet-mapping>
4.在工程的struts.xml文件中加入如下内容:
<constant name="struts.action.excludePattern" value=".*/lucene/.*" />
5.在spring中加入任务,定时更新索引。更新索引代码如下:
@Scheduled(cron = "20 46 12 ? * *")
public void createIndex() {
String appPath = LuceneScheduler.class.getResource("/").toString();
appPath = StringUtils.substringAfter(
StringUtils.substringBefore(appPath, "WEB-INF"), "/");
String docPath = appPath + "upload/";
try {
File file = new File(docPath);
String urlString = constant.getUrl();
StreamingUpdateSolrServer solr = new StreamingUpdateSolrServer(
urlString, 1, 1);
solr.deleteByQuery( "*:*" );
solr.blockUntilFinished();
indexFilesSolrCell(file.listFiles(), solr);
} catch (Exception e) {
e.printStackTrace();
}
}
private void indexFilesSolrCell(File[] fileList,
StreamingUpdateSolrServer solr) throws IOException,
SolrServerException, InterruptedException {
for (File file : fileList) {
if (file.isFile()) {
ContentStreamUpdateRequest up = new ContentStreamUpdateRequest(
"/update/extract");
up.addFile(file);
up.setParam("uprefix", "attr_");
up.setParam("fmap.content", "attr_content");
up.setParam("literal.id", file.getPath());
up.setAction(AbstractUpdateRequest.ACTION.COMMIT, false, false);
solr.request(up);
solr.blockUntilFinished();
System.out.println("Analysis file:" + file.getPath());
} else if (file.isDirectory()) {
indexFilesSolrCell(file.listFiles(), solr);
}
}
}
6.接下来,便可对已索引的文件进行全文检索,如下是struts中的action类内容:
@Autowired
private Constant constant;
private String search;
private List<SearchItem> searchItemList = new ArrayList<SearchItem>();
public String list() {
String urlString = constant.getUrl();
try {
StreamingUpdateSolrServer solr = new StreamingUpdateSolrServer(
urlString, 1, 1);
if (StringUtils.isNotBlank(search)) {
QueryResponse rsp = solr.query(new SolrQuery("attr_content:"
+ search));
SolrDocumentList solrDocumentList = rsp.getResults();
for (SolrDocument solrDocument : solrDocumentList) {
SearchItem searchItem = new SearchItem();
searchItem.setHref(solrDocument.getFieldValue("id")
.toString());
String content = removeSpecial(solrDocument.getFieldValue(
"attr_content").toString());
content = StringUtils.left(content, 30);
searchItem.setContent(content);
String title = "";
Object titleO = solrDocument.getFieldValue("title");
if (titleO == null) {
title = StringUtils.left(content, 10);
} else {
title = removeSpecial(titleO.toString());
}
searchItem.setTitle(title);
searchItemList.add(searchItem);
}
}
} catch (Exception e) {
e.printStackTrace();
}
return "list";
}
private String removeSpecial(String str) {
str = StringUtils.substringAfter(str, "[");
str = StringUtils.substringBeforeLast(str, "]");
str = StringUtils.trim(str);
return str;
}
public String getSearch() {
return search;
}
public void setSearch(String search) {
this.search = search;
}
public List<SearchItem> getSearchItemList() {
return searchItemList;
}
public void setSearchItemList(List<SearchItem> searchItemList) {
this.searchItemList = searchItemList;
}
分享到:
相关推荐
- SolrJ:Java客户端API,用于在Java应用中集成Solr。 - Solr Admin UI:Solr内置的Web管理界面,方便配置、监控和调试。 - IDE插件:如Eclipse的Solr插件,提升开发效率。 通过学习以上内容,并结合提供的参考...
8. **整合到JavaEE框架**:将Lucene集成到Spring、Struts或JSF等JavaEE框架中,可以简化开发流程,提高代码的可维护性。例如,使用Spring Data的Lucene模块可以便捷地管理索引操作。 9. **错误处理与调试**:在实际...
6. **分布式搜索**:在大型Web应用中,Lucene可以扩展到分布式环境,如Solr或Elasticsearch,它们在多个服务器上分布索引和查询,提供高可用性和性能。 7. **更新和删除**:Lucene支持实时索引更新,当文档被修改或...
Struts2+Spring3+Hibernate3是Java开发中常见的企业级应用框架组合,被称为SSH框架。这个商城系统利用这三个框架的协同工作,构建了一个高效、稳定且功能丰富的平台。接下来,我们将深入探讨这些关键技术及其在商城...
在Java世界中,可能会使用Lucene或Solr这样的搜索引擎库,或者直接在数据库层面实现搜索功能,通过SQL的LIKE或全文搜索语句进行查询。 这个压缩包文件"StrutsArticle_release"很可能包含了项目的源代码、配置文件、...
集成Lucene到SSH2框架中,首先需要在Spring配置文件中定义Lucene的相关bean,包括IndexWriter、Directory等。然后,可以通过Spring的AOP(面向切面编程)或者Service层来调用Lucene的API进行索引构建和查询操作。...
5. **兼容性好**:与主流的Java应用框架如Spring、Struts等兼容,便于集成到各种项目中。 在**IK Analyzer 2012FF_hf1** 中,"FF"可能代表Final Fix,表示这是该版本的最终修复版,而"hf1"则可能表示这是一个高频率...
在实际应用中,开发者通常会将IKAnalyzer集成到基于Lucene或Solr的信息检索系统中,或者在Spring、Struts等框架下开发Web应用时作为后端的文本处理组件。通过调用IKAnalyzer提供的API,可以实现对用户输入的中文文本...
Spring Email模块提供了发送邮件的功能,支持HTML邮件、附件等,可以方便地集成到应用中。 8. 用户界面: JSP 2.0 和 FreeMarker 是模板引擎,用于生成动态网页内容。JQuery是一个强大的JavaScript库,简化了DOM...
【描述】中提到,该系统已经集成了运行所需的环境,用户只需将其部署到合适的服务器环境中即可使用。这里涉及的关键技术点包括: 1. **JSP**: JSP是一种动态网页技术,它允许开发者在HTML页面中嵌入Java代码,实现...
5. **搜索功能**:通过Lucene或Solr实现全文搜索,使用户能快速找到所需书籍。 6. **商品展示**:使用JSP或Thymeleaf等模板引擎来渲染网页,实现动态展示和交互。 7. **异常处理**:全局异常捕获和处理,提供友好...
他还熟悉RabbitMQ消息队列,用于系统间的通信,具备基本的Linux命令操作能力,以及Lucene和Solr全文搜索引擎工具的了解。 刘行浩的工作经历中包括了三个具体项目: 1. **恋e网上商城** - 使用Springmvc、Spring、...
Lucene是全文搜索引擎库,Solr是基于Lucene的搜索服务器。学习如何实现高效的文本搜索功能。 【学习阶段16】就业指导(79天): 这个阶段可能包含简历撰写、面试技巧、职业规划等内容,帮助你更好地准备进入IT行业...
这可能涉及到Lucene或Solr等搜索引擎的集成。 9. **安全考虑**: 需要防止SQL注入、XSS攻击等网络安全问题,Struts 2和Spring都提供了相应的防护措施,如使用预编译的SQL语句、过滤输入数据等。 10. **测试与部署...
这可能涉及到全文搜索,可以使用开源的全文搜索引擎如Lucene或Solr。 10. **错误处理与日志记录**:良好的错误处理机制和日志记录是任何系统不可或缺的部分。通过Log4j等工具记录运行时信息,有助于问题排查和系统...
7. **搜索功能**:为了方便用户查找信息,社区站点可能会集成全文搜索引擎如Lucene或Solr,以实现高效的站内搜索。 8. **社区功能**:项目中可能包括用户注册、登录、发帖、回帖、收藏、评分、举报等功能,这些都是...
- 全文搜索:掌握Lucene、Compass和Solr。 - Web Service:熟悉Web Service技术。 - 版本控制和构建工具:能使用SVN、Maven。 - Linux:熟练使用Linux常用命令。 - NoSQL:了解MongoDB,以及主从集群、分布式...
* Solr/Lucene/HBase/Hive/Kylin 基础:掌握 Solr、Lucene、HBase、Hive、Kylin 等框架的使用。 * Spring/Spring Boot/Spring Security/Spring Data/Spring Data JPA/Spring Data MongoDB/Spring Data Redis 基础:...
7. **搜索功能**:可能使用全文搜索引擎如Lucene或Solr,实现论坛内容的快速检索。 这两个项目结合在一起,可以帮助学习者深入理解JavaEE的全貌,从基础的Servlet和JSP,到复杂的EJB、Struts、Spring、Hibernate等...
9. **搜索功能**:论坛通常提供关键词搜索,这就需要理解全文搜索的概念,可能涉及Lucene或Solr等搜索引擎库,或者集成Elasticsearch实现高级搜索功能。 10. **AJAX异步通信**:为了提升用户体验,论坛可能会使用...