Java

本类阅读TOP10

·使用MyEclipse开发Struts框架的Hello World!(录像1)
·hibernate配置笔记
·AOP编程入门--Java篇
·linux下Tomcat 5.0.20 与 Apache 2 安装/集成/配置
·在win2003下整合了整合Tomcat5.5+ apache_2.0.53+ mod_jk_2.0.47.dll
·构建Linux下IDE环境--Eclipse篇
·Jsp 连接 mySQL、Oracle 数据库备忘(Windows平台)
·ASP、JSP、PHP 三种技术比较
·Tomcat5.5.9的安装配置
·AWT GUI 设计笔记(二)

分类导航
VC语言Delphi
VB语言ASP
PerlJava
Script数据库
其他语言游戏开发
文件格式网站制作
软件工程.NET开发
Atlassian Confluence 的中文搜索问题的解决

作者:未知 来源:月光软件站 加入时间:2005-2-28 月光软件站

Atlassian Confluence  我觉得是个适合用来做项目开发时的wiki工具,当然它是商业的,如果你是开源项目,可以申请一个开源的license,用起来就是爽啊.
 
不过原版的程序对中文搜索可是不行啊,它的搜索用的是lucene 1.4, 也就是说lucene的中文搜索没有被利用上(当然lucene包里缺省没有中文的,而且confluence也没有调用相关的包,对比JIra,还是有点问题,当然JIra至少可以配置,随便也没有中文的)
 
通过研究,lucene可以用CJKAnalyzer 来做中文搜索,虽然有着这样那样的缺点,毕竟可以用(暂时不讨论这个分词的问题,可以用就行了)
 
搜索confluence的相关文件,发现有个lucene.cfg.xml,里面调用了一个factory类:  bucket.search.lucene.analyzer.DefaultLuceneAnalyzerFactory
 
另外indexingSubsystemContext.xml 里面也调用了这个类
 
恩,自己写个类替换掉这个类,或者改改配置文件就可以搞定了.
 
打开eclipse,建立一个新的项目,加入lucene的jar包,加入atlassian-bucket-0.6.9.jar
 
新建一个类来替代原来的类,例如 ScudLuceneAnalyzerFactory
 
代码如下:
 
package org.apache.lucene.analysis;
import org.apache.lucene.analysis.cjk.CJKAnalyzer;
import bucket.search.lucene.analyzer.LuceneAnalyzerFactory;

public class ScudLuceneAnalyzerFactory implements LuceneAnalyzerFactory
{
 public ScudLuceneAnalyzerFactory()
 {
 }
 public Analyzer createAnalyzer()
 {
  return new CJKAnalyzer();
 }
 
}
 
编译,打成一个jar包,放到confluence的WEB-INF/lib目录下,修改上面提到的配置文件中的factory类为你的类.
 
重启tomcat,重建索引, ok,可以搜索中文了(当然英文也没问题)

 
---说得太详细了...这样不好 嘿嘿



相关文章

相关软件