SolrJ带账号密码实现增删查:索引添加与安全连接示例

4星 · 超过85%的资源 需积分: 50 64 下载量 200 浏览量 更新于2024-09-09 1 收藏 56KB DOC 举报
本文档主要介绍了在Java中使用SolrJ库与Solr 6.0版本的服务器进行交互,特别是当需要通过HTTP Basic Auth方式(即带账号密码)进行安全连接时的操作。作者首先提到了在Maven项目中添加solr-solrj依赖,这是与Solr服务器进行通信的关键组件,版本为6.0.0。 在实现过程中,作者创建了一个名为`SolrQueryUtill`的工具类,其中包含了与Solr服务器交互的核心方法。该类中的`connect()`方法用于建立与Solr服务器的连接,它使用`HttpSolrClient`来执行请求。为了保证安全连接,方法中设置了`HttpClientUtil`的属性,如`PROP_CONNECTION_TIMEOUT`用于设置连接超时时间,`PROP_FOLLOW_REDIRECTS`设置是否跟随重定向,而`PROP_BASIC_AUTH_USER`和`PROP_BASIC_AUTH_PASS`则是用来设置Solr服务器的用户名和密码。 值得注意的是,尽管作者能够成功地进行查询操作,但更新操作(例如添加索引)因为权限问题未能实现。这可能是因为Solr服务器的配置限制或者请求头中缺少必要的认证信息。在实际应用中,为了进行索引添加,可能需要在`params`对象中增加`add`参数,并确保SolrJ客户端有适当的权限级别,允许对索引进行写操作。 此外,如果遇到问题,还需要检查Solr服务器的配置文件(如solrconfig.xml和schema.xml),确保授权规则正确,允许指定的用户执行相应的操作。同时,可能需要确认SolrJ客户端是否正确设置了角色映射或者权限策略。 本篇文章提供了一个基础的SolrJ客户端使用示例,重点在于通过HTTP Basic Auth与Solr服务器进行安全连接,并展示了如何进行查询操作。然而,对于更复杂的操作,如添加索引,还需要深入理解Solr的安全模型和客户端配置。