异常信息(使用solr高亮):
java.lang.String cannot be cast to java.util.List
解决方案:这个solr源码内部(solrj包)类型转换异常,可以使用相同路径代码覆盖,若使用/analysis/field要修改FieldAnalysisResponse的buildAnalysis方法,修改前源码如下:
private Analysis buildAnalysis(NamedList<NamedList<List<NamedList<Object>>>> value) {
Analysis analysis = new Analysis();
NamedList<List<NamedList<Object>>> queryNL = value.get("query");
List<AnalysisPhase> phases = (queryNL == null) ? null : buildPhases(queryNL);//此处为错误
analysis.setQueryPhases(phases);
NamedList<List<NamedList<Object>>> indexNL = value.get("index");
phases = buildPhases(indexNL);
analysis.setIndexPhases(phases);
return analysis;
}
修改成如下:
private Analysis buildAnalysis(NamedList<NamedList<List<NamedList<Object>>>> value) {
Analysis analysis = new Analysis();
NamedList<List<NamedList<Object>>> mid = new NamedList<List<NamedList<Object>>>();
NamedList<List<NamedList<Object>>> queryNL = value.get("query");
for(Map.Entry<String, List<NamedList<Object>>> map : queryNL) {
if(map.getKey().contains("Tokenizer")) {//保存是分词器的
mid.add(map.getKey(),map.getValue());}
}
List<AnalysisPhase> phases = (mid == null) ? null : buildPhases(mid);
analysis.setQueryPhases(phases);
mid.clear();//清空数据
NamedList<List<NamedList<Object>>> indexNL = value.get("index");
for(Map.Entry<String, List<NamedList<Object>>> map : indexNL) {
if(map.getKey().contains("Tokenizer")) {//保存是分词器的
mid.add(map.getKey(),map.getValue());}
}
phases = buildPhases(mid);
analysis.setIndexPhases(phases);
return analysis;
}
若使用/analysis/document要修改DocumentAnalysisResponse的buildAnalysis方法,修改方法同上。
注意:若修改完成后,不起作用,可查看Build Path-->Order and Export
这样重新调用就可以使用了,结果如下。
java.lang.NoSuchMethodError: javax.servlet.ServletInputStream.isFinished错误
原因是solr5.5采用JDK1.7打包,而且weblogic12c使用JDK1.7,但在solr内部会使用JDK1.8中新添加的isFinished()方法,因此会报错,且是在部署成功之后,访问时报错!!!
解决方案:首先根据log定位到最终报错的位置,在源码中的位置如下:
分析可以在此处使用此方法没有具体是事务,因此可以考虑屏蔽掉该行代码,会回溯到weblogic12c访问的源头修改jdk的版本,但不建议这样!