私は Apache Solr を使い始めたばかりで、大きな PHP クラックでもありません。
Apache Solr が実行されており、ブラウザーにこのクエリを貼り付けると、XML ドキュメントが表示されます。
http://localhost:8983/solr/my_test/select?q=name:%22A%20Clash%20of%20Kings%22
ただし、次のコードは UnexpectedValueException をスローします。
<?php
require __DIR__.'/vendor/autoload.php';
// check solarium version available
echo 'Solarium library version: ' . Solarium\Client::VERSION . ' - ';
$config = array(
'endpoint' => array(
'localhost' => array(
'host' => '127.0.0.1', 'port' => '8983', 'path' => '/solr/#/my_test/select?q=name:"A Clash of Kings"'
)
)
);
// create a client instance
$client = new Solarium\Client($config);
// // get a select query instance
$query = $client->createQuery($client::QUERY_SELECT);
// // this executes the query and returns the result
$resultset = $client->execute($query);
// display the total number of documents found by solr
echo 'NumFound: '.$resultset->getNumFound(); // THROWS EXCEPTION
// create a ping query
$ping = $client->createPing();
// // execute the ping query
try {
$result = $client->ping($ping);
echo 'Ping query successful';
echo '<br/><pre>';
var_dump($result->getResponse());
echo '</pre>';
} catch (Solarium\Exception $e) {
echo 'Ping query failed';
}
?>
出力:
Solarium library version: 3.0.0 -
Fatal error: Uncaught exception 'Solarium\Exception\UnexpectedValueException'
with message 'Solr JSON response could not be decoded' in C:\Server\xampp\htdocs\HTML\php\vendor\solarium\solarium\library\Solarium\Core\Query\Result\Result.php:158 Stack trace: #0
C:\Server\xampp\htdocs\HTML\php\vendor\solarium\solarium\library\Solarium\QueryType\Select\ResponseParser\ResponseParser.php(61):
Solarium\Core\Query\Result\Result->getData() #1
C:\Server\xampp\htdocs\HTML\php\vendor\solarium\solarium\library\Solarium\Core\Query\Result\QueryType.php(73):
Solarium\QueryType\Select\ResponseParser\ResponseParser->parse(Object(Solarium\QueryType\Select\Result\Result)) #2
C:\Server\xampp\htdocs\HTML\php\vendor\solarium\solarium\library\Solarium\QueryType\Select\Result\Result.php(144): Solarium\Core\Query\Result\QueryType->parseResponse() #3 C:\Server\xampp\htdocs\HTML\php\lucene.php(25):
Solarium\QueryType\Select\Result\Result->getNumFound() #4 {main} thrown in C:\Server\xampp\htdocs\HTML\php\vendor\solarium\solarium\library\Solarium\Core\Query\Result\Result.php on line 158
Github の投稿を読んだ後、次のように変更しました。
var_dump($result->getData());
へのpingクエリで
var_dump($result->getResponse());
getData もこの例外をスローしたためです。
少し驚いたのは、
Solr JSON response could not be decoded
ただし、ブラウザーで URL を直接使用すると、XML が返されます。メッセージのフォーマットをどこかで設定する必要がありますか? XML から JSON に、またはその逆に変更する必要がありますか? Windows 7 で Solr 5.3.1 を使用しています。
例外をスローする行をコメントアウトすると、応答は次のようになります。
Solarium library version: 3.0.0 - Ping query successful
object(Solarium\Core\Client\Response)#8 (4) {
["headers":protected]=>
array(1) {
[0]=>
string(15) "HTTP/1.1 200 OK"
}
["body":protected]=>
string(6243) "