弹性搜索查询和PHP中的cURL

时间:2012-07-25 10:14:54

标签: php curl elasticsearch

我刚开始使用elasticsearch。我想在php中使用cURL进行查询。

此代码不提供任何内容...(如果我从命令行执行,请参阅下面的错误。我不确定此错误是否是由于控制台中的换行符引起的...)

$url = "curl -s -XGET http://<my_url>:9200/idx_occurrence/Occurrence/_search -d '
{
'filtered' : {
    'query' : {
        'term' : { 'kingdom_interpreted' : 'Plantae' }
    }
}

}' ";

$ch = curl_init();

curl_setopt($ch, CURLOPT_URL, $url);

curl_setopt($ch, CURLOPT_HEADER, 0);

$return=curl_exec($ch);

var_dump($return);

但如果我使用此网址http://<my_url>:9200/idx_occurrence/Occurrence/_search?q=kingdom_interpreted:Plantae

然后我从cURL获得结果。

也许查询过滤器可能不正确? (我尝试了几个选项但没有成功)

  

错误:{“error”:“SearchPhaseExecutionException [无法执行阶段[查询],完全失败; shardFailures {[AS6HqxgNRtyU9-pQKhJsXQ] [idx_occurrence] [3]:SearchParseException [[idx_occurrence] [3]:from [ - 1],大小[-1]:解析失败[无法解析源[\ n {\ n已过滤:{\ n查询:{\ n术语:{王国:植物园} \ n} \ n} \ n} \ n}]]嵌套:SearchParseException [[idx_occurrence] [3]:from [-1],size [-1]:Parse Failure [没有解析器元素[filtered]]];} {[AS6HqxgNRtyU9-pQKhJsXQ] [idx_occurrence] [2] ]:SearchParseException [[idx_occurrence] [2]:from [-1],size [-1]:Parse Failure [无法解析源[\ n {\ n已过滤:{\ n查询:{\ n term:{kingdom :Plantae} \ n} \ n} \ n}]]];嵌套:SearchParseException [[idx_occurrence] [2]:from [-1],size [-1]:Parse Failure [没有元素[filtered]的解析器] ];}]“,”状态“:500}

4 个答案:

答案 0 :(得分:6)

我一直在使用Elastica PHP库进行弹性搜索交互:

https://github.com/ruflin/Elastica

学习曲线很短。这是一个例子:

$client = new Elastica_Client();
$index = $client->getIndex('idx_occurrence');
$index->getType('Occurrence');

$query_string = new Elastica_Query_QueryString('Plantae');
$query_string->setFields(array('kingdom_interpreted'));    
$query = new Elastica_Query($query_string);

$index->refresh();
$searchResults = $index->search($query);

这说明了一个限于特定字段的查询字符串搜索。 $searchResultsElastica_ResultSet个对象的数组。我喜欢Elastica,因为它抽象出任何与cURL相关的问题。

答案 1 :(得分:2)

这是一个简单的请求演示:

    $param = "
        {
        'filtered' : {
            'query' : {
                'term' : { 'kingdom_interpreted' : 'Plantae' }
            }
        }

        }";
    $header = array(
        "content-type: application/x-www-form-urlencoded; charset=UTF-8"
    );

    $curl = curl_init();
    curl_setopt($curl, CURLOPT_URL, "http://xxxxx:9200/idx_occurrence/Occurrence/_search");
    curl_setopt($curl,CURLOPT_HTTPHEADER, $header);
    curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
    curl_setopt($curl, CURLOPT_POSTFIELDS, $param);
    $res = curl_exec($curl);
    curl_close($curl);
    return $res;

答案 2 :(得分:1)

我自己找到了答案的一部分。 我设法通过命令行获取它。

curl -XGET my_server:9200/idx_occurrence/Occurrence/_search?pretty=true -d '{ "query": { "query_string" :{"fields" : ["kingdom_interpreted"], "query": "Plantae" } } }'

使用PHP执行(正确的)cURL请求只返回一个空字符串。 PHP日志中没有错误。

$url='curl -XGET http://<my_url>:9200/idx_occurrence/Occurrence/_search?pretty=true
 -d   \'{ "query": { "query_string" :{ "fields" : ["kingdom_interpreted"], 
"query": "Plantae" } } }\'';

$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_HEADER, 0);
ob_start();
curl_exec ($ch);
curl_close ($ch);
$data = ob_get_contents();
ob_end_clean();
var_dump($data);

同样,如果不是这个$ url,我发送这个url my_url:9200 / idx_occurrence / Occurrence / _search?q = kingdom_interpreted:Plantae

有效。为什么呢?

答案 3 :(得分:0)

$search = 'Plantae'; //search query
$fields = 'kingdom_interpreted'; //fields to look in
$results = file_get_contents('http://server:port/idx_occurrence/Occurrence/_search?q='.$search.'&fields='.$fields);