2

我正在使用Solr PHP ClientSolr 4.3.0启动并运行示例。我没有修改schema.xml文件。当我运行此代码时,出现400错误:

Uncaught exception 'Apache_Solr_HttpTransportException' with message '400' Status: Bad Request.'

该文档未显示在索引中。有趣的是,如果我重新启动Jetty,文档就会被索引。这是我的代码。我想知道我是否遗漏了什么。我认为这是我的输入与架构匹配的问题,但id似乎是唯一的必填字段,而这些其他字段在架构中。我不知道该怎么办。

require_once('SolrPhpClient/Apache/Solr/Service.php');

$solr = new Apache_Solr_Service('localhost', 8983, '/solr/');

if($solr->ping() == null){
    die('could not ping solr');
}

$document = new Apache_Solr_Document();
$document->id = 'guid1';
$document->title = 'Title1';
$document->subject = 'The subject is solr';
$document->description = 'This is the description';

$solr->addDocument($document);
$solr->commit();

我得到的完整错误信息是

Fatal error: Uncaught exception 'Apache_Solr_HttpTransportException' with message ''400' Status: Bad Request' in C:\xampp\htdocs\dev\SolrPhpClient\Apache\Solr\Service.php:364 
Stack trace: 
#0 C:\xampp\htdocs\dev\SolrPhpClient\Apache\Solr\Service.php(829): Apache_Solr_Service->_sendRawPost('http://localhos...', '<commit expunge...', 3600)  
#1 C:\xampp\htdocs\dev\indexerSOLR_PHP.php(20): Apache_Solr_Service->commit()  
#2 {main} thrown in C:\xampp\htdocs\dev\SolrPhpClient\Apache\Solr\Service.php on line 364`
4

4 回答 4

4

这是 Solr 4.x 和从 Solr PHP 客户端调用提交的已知问题。请参阅 错误 #62332 - 从 solr 4.0 开始,已删除 waitFlush 参数以获取详细信息和修复问题的补丁。

于 2013-05-16T15:58:28.337 回答
2

这就是我得到解决方案的方式,我修改了提交方法。在 _updateurl 变量中添加了“&commit=true”。

public function commit($expungeDeletes = false, $waitFlush = true, $waitSearcher = true, $timeout = 3600)
{
    $expungeValue = $expungeDeletes ? 'true' : 'false';
    $flushValue = $waitFlush ? 'true' : 'false';
    $searcherValue = $waitSearcher ? 'true' : 'false';

    //$rawPost = '<commit expungeDeletes="' . $expungeValue . '" waitFlush="' . $flushValue . '" waitSearcher="' . $searcherValue . '" />';
            //$this->post=$rawPost;        
    return $this->_sendRawGet($this->_updateUrl.'&commit=true', $timeout);
}
于 2013-05-30T20:22:04.030 回答
0

你已经改变了这条线。

require_once('SolrPhpClient/Apache/Solr/Service.php'); => require_once('Service.php');

也许Service.php这个文件的路径不对。我试图改变这条线。然后顺利工作。

于 2013-06-04T07:51:02.013 回答
0

我遇到了同样的问题,因为我安装了旧版本的 PHP Solr 扩展(0.9.11)。

要获得最新的:

pecl download solr-beta
tar xvzf solr-2.1.0.tgz # This can be different depending on the last release number
cd solr-2.1.0/
phpize
./configure
make
sudo make install
# add extension=solr.so to your php.ini / distribution extension loader

感谢这篇文章

于 2015-03-18T02:42:27.703 回答