`
qingwei201314
  • 浏览: 168622 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

lucene solr配置,集成到struts中

 
阅读更多

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;
 }

分享到:
评论
1 楼 mythet 2012-08-13  
上面的配置有问题,测试半天都访问不了,原因是web.xml缺少了关键的配置。

<filter>
     <filter-name>SolrRequestFilter</filter-name>
     <filter-class>org.apache.solr.servlet.SolrDispatchFilter
     </filter-class>
  <init-param>
      <param-name>path-prefix</param-name>
      <param-value>/lucene</param-value>
     </init-param>

</filter>

相关推荐

    solr_开发入门例子

    - SolrJ:Java客户端API,用于在Java应用中集成Solr。 - Solr Admin UI:Solr内置的Web管理界面,方便配置、监控和调试。 - IDE插件:如Eclipse的Solr插件,提升开发效率。 通过学习以上内容,并结合提供的参考...

    基于lucene的开发JavaEE项目

    8. **整合到JavaEE框架**:将Lucene集成到Spring、Struts或JSF等JavaEE框架中,可以简化开发流程,提高代码的可维护性。例如,使用Spring Data的Lucene模块可以便捷地管理索引操作。 9. **错误处理与调试**:在实际...

    WebLucene2.zip

    6. **分布式搜索**:在大型Web应用中,Lucene可以扩展到分布式环境,如Solr或Elasticsearch,它们在多个服务器上分布索引和查询,提供高可用性和性能。 7. **更新和删除**:Lucene支持实时索引更新,当文档被修改或...

    struts2+spring3+hibernate3实现商城系统

    Struts2+Spring3+Hibernate3是Java开发中常见的企业级应用框架组合,被称为SSH框架。这个商城系统利用这三个框架的协同工作,构建了一个高效、稳定且功能丰富的平台。接下来,我们将深入探讨这些关键技术及其在商城...

    文章管理系统(struts+jsp)

    在Java世界中,可能会使用Lucene或Solr这样的搜索引擎库,或者直接在数据库层面实现搜索功能,通过SQL的LIKE或全文搜索语句进行查询。 这个压缩包文件"StrutsArticle_release"很可能包含了项目的源代码、配置文件、...

    search.rar

    集成Lucene到SSH2框架中,首先需要在Spring配置文件中定义Lucene的相关bean,包括IndexWriter、Directory等。然后,可以通过Spring的AOP(面向切面编程)或者Service层来调用Lucene的API进行索引构建和查询操作。...

    IK Analyzer 2012FF_hf1

    5. **兼容性好**:与主流的Java应用框架如Spring、Struts等兼容,便于集成到各种项目中。 在**IK Analyzer 2012FF_hf1** 中,"FF"可能代表Final Fix,表示这是该版本的最终修复版,而"hf1"则可能表示这是一个高频率...

    IKAnalyzer2012_u6.zip

    在实际应用中,开发者通常会将IKAnalyzer集成到基于Lucene或Solr的信息检索系统中,或者在Spring、Struts等框架下开发Web应用时作为后端的文本处理组件。通过调用IKAnalyzer提供的API,可以实现对用户输入的中文文本...

    jeefuseMDA用户开发手册1

    Spring Email模块提供了发送邮件的功能,支持HTML邮件、附件等,可以方便地集成到应用中。 8. 用户界面: JSP 2.0 和 FreeMarker 是模板引擎,用于生成动态网页内容。JQuery是一个强大的JavaScript库,简化了DOM...

    基于jsp的BBS论坛系统

    【描述】中提到,该系统已经集成了运行所需的环境,用户只需将其部署到合适的服务器环境中即可使用。这里涉及的关键技术点包括: 1. **JSP**: JSP是一种动态网页技术,它允许开发者在HTML页面中嵌入Java代码,实现...

    SSH网上书店

    5. **搜索功能**:通过Lucene或Solr实现全文搜索,使用户能快速找到所需书籍。 6. **商品展示**:使用JSP或Thymeleaf等模板引擎来渲染网页,实现动态展示和交互。 7. **异常处理**:全局异常捕获和处理,提供友好...

    java3年工作经验简历_java简历.doc

    他还熟悉RabbitMQ消息队列,用于系统间的通信,具备基本的Linux命令操作能力,以及Lucene和Solr全文搜索引擎工具的了解。 刘行浩的工作经历中包括了三个具体项目: 1. **恋e网上商城** - 使用Springmvc、Spring、...

    java学习过程资源

    Lucene是全文搜索引擎库,Solr是基于Lucene的搜索服务器。学习如何实现高效的文本搜索功能。 【学习阶段16】就业指导(79天): 这个阶段可能包含简历撰写、面试技巧、职业规划等内容,帮助你更好地准备进入IT行业...

    javaEE 论坛系统

    这可能涉及到Lucene或Solr等搜索引擎的集成。 9. **安全考虑**: 需要防止SQL注入、XSS攻击等网络安全问题,Struts 2和Spring都提供了相应的防护措施,如使用预编译的SQL语句、过滤输入数据等。 10. **测试与部署...

    基于javaEE的文档管理系统.zip

    这可能涉及到全文搜索,可以使用开源的全文搜索引擎如Lucene或Solr。 10. **错误处理与日志记录**:良好的错误处理机制和日志记录是任何系统不可或缺的部分。通过Log4j等工具记录运行时信息,有助于问题排查和系统...

    ssh社区站点项目(bbs)

    7. **搜索功能**:为了方便用户查找信息,社区站点可能会集成全文搜索引擎如Lucene或Solr,以实现高效的站内搜索。 8. **社区功能**:项目中可能包括用户注册、登录、发帖、回帖、收藏、评分、举报等功能,这些都是...

    Java个人简历模板4.doc

    - 全文搜索:掌握Lucene、Compass和Solr。 - Web Service:熟悉Web Service技术。 - 版本控制和构建工具:能使用SVN、Maven。 - Linux:熟练使用Linux常用命令。 - NoSQL:了解MongoDB,以及主从集群、分布式...

    Java学习路线图.pdf

    * 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 基础:...

    学习JavaEE的两个著名工程PetStore和Jive论坛二合一

    7. **搜索功能**:可能使用全文搜索引擎如Lucene或Solr,实现论坛内容的快速检索。 这两个项目结合在一起,可以帮助学习者深入理解JavaEE的全貌,从基础的Servlet和JSP,到复杂的EJB、Struts、Spring、Hibernate等...

    java web论坛模块

    9. **搜索功能**:论坛通常提供关键词搜索,这就需要理解全文搜索的概念,可能涉及Lucene或Solr等搜索引擎库,或者集成Elasticsearch实现高级搜索功能。 10. **AJAX异步通信**:为了提升用户体验,论坛可能会使用...

Global site tag (gtag.js) - Google Analytics