欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

elaticserach ik自定义远程词库的方法 博客分类: java elaticsearch es 

程序员文章站 2024-02-07 13:31:58
...
这是ik的配置文件  在配置远程扩展字典写上下面方法的接口(要注意能调取到这个方法) 把停止词典注释掉
---------------------------------------------------------------------------
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE properties SYSTEM "http://java.sun.com/dtd/properties.dtd">
<properties>
<comment>IK Analyzer 扩展配置</comment>
<!--用户可以在这里配置自己的扩展字典 -->
<entry key="ext_dict">custom/mydict.dic;custom/single_word_low_freq.dic</entry>
<!--用户可以在这里配置自己的扩展停止词字典-->
<entry key="ext_stopwords">custom/ext_stopword.dic</entry>
<!--用户可以在这里配置远程扩展字典 -->
<entry key="remote_ext_dict">location</entry>
<!--用户可以在这里配置远程扩展停止词字典-->
<entry key="remote_ext_stopwords">http://xxx.com/xxx.dic</entry>
</properties>
---------------------------------------------------------------------------
以下是java代码部分
---------------------------------------------------------------------------
@GET
    @Path("loadGJCK")
    @Produces(MediaType.APPLICATION_OCTET_STREAM)
    @ApiOperation(value = "词库")
    public String  loadGJCK(@Context HttpServletRequest request,@Context HttpServletResponse response){
        String result = "";
        try {

            StringBuilder sb = new StringBuilder();
            String[] keywords = keywordService.selectKeyWord(10l);//获取所有分词,这里可以改进使用缓存等。

            String eTag = request.getHeader("If-None-Match");
            Long modified= request.getDateHeader("If-Modified-Since");

            //设置头
            if(null == modified || -1 == modified) {
                //如果没有,则使用当前时间
                modified = System.currentTimeMillis();
            }
            // 设置头信息。
            String oldEtag = keywords.length+ "";
            response.setDateHeader("Last-Modified", Long.valueOf(modified));
            response.setHeader("ETags", keywords.length + "");

            if(!oldEtag.equals(eTag)) {
                //拼装结果
                for(String tempWord : keywords) {
                    if(!StringUtils.isEmpty(tempWord)){
                        //分词之间以换行符连接
                        if(StringUtils.isNotEmpty(sb.toString())) {
                            sb.append("\r\n");
                        }
                        sb.append(tempWord);
                    }
                }
                //result = new String(result.getBytes("ISO8859-1"), "UTF-8");
                result = sb.toString();
                //更新时间
                response.setDateHeader("Last-Modified", System.currentTimeMillis());
            }

        }catch (Exception e){
            e.printStackTrace();
        }finally {
            System.out.println(result);
            return result;
        }
    }


然后这个词库就可以用啦!
相关标签: elaticsearch es