问题描述:
最近在用solrj做索引查询时,发现由于查询的参数过长,会导致在查询时报错,最后查询失败。报错信息如下截图:
根据业务需求,在查询数据时需要做一下过滤,而不想改动太大的原有代码,所以只能在查询的时候传入一些参数,进行查询的条件过滤,而查询的时候,因为携带的参数过长,导致在solrj调用查询的方法时直接抛出了异常,查询失败,异常信息如上图所示。根据测试,当携带的参数比较小的时候,发现查询可以正常执行,并且能返回查询结果。所以判断引起异常的原因为solrj发送查询请求携带参数过长引起的。网上查询了一下查询的错误信息,没有找到正确的答案,后来仔细考虑了一下,想到应该是查询参数太长导致异常发生,看了一下solrj发送请求用的是httpclient,而QueryResponse这个对象创建的时候,默认用的是“get”请求方式,如果参数过大就会导致异常的发生,所以解决的办法就是修改发送请求的方式,也就是将请求改为post方式。即在创建QueryResponse时,添加一个参数。如下:
SolrQuery query = new SolrQuery();
QueryResponse qr = solr.query(query,METHOD.POST);
其中solr为创建的客户端连接。这样在查询的时候,不管携带的参数有多大,都不会在报错了。