简体   繁体   English

弹性搜索查询和PHP中的cURL

[英]elasticsearch query and cURL in PHP

I am just starting with elasticsearch. 我刚开始使用elasticsearch。 I want to query using cURL in php. 我想在php中使用cURL进行查询。

This code gives nothing... (see error below if I execute from command line. I am not sure that this error is caused of line breaks in console...) 这段代码什么都没有...(如果我从命令行执行,请参阅下面的错误。我不确定这个错误是否是由于控制台中的换行...)

$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);

but if I use this url http://<my_url>:9200/idx_occurrence/Occurrence/_search?q=kingdom_interpreted:Plantae 但如果我使用这个网址http://<my_url>:9200/idx_occurrence/Occurrence/_search?q=kingdom_interpreted:Plantae

then I get results from cURL. 然后我从cURL得到结果。

Maybe may query filter is incorrect? 也许可能查询过滤器不正确? (I tried several options without success) (我尝试了几个选项没有成功)

ERROR: {"error":"SearchPhaseExecutionException[Failed to execute phase [query], total failure; shardFailures {[AS6HqxgNRtyU9-pQKhJsXQ][idx_occurrence][3]: SearchParseException[[idx_occurrence][3]: from[-1],size[-1]: Parse Failure [Failed to parse source [\\n{\\n filtered : {\\n query : {\\n term : { kingdom : Plantae }\\n }\\n}\\n}]]]; nested: SearchParseException[[idx_occurrence][3]: from[-1],size[-1]: Parse Failure [No parser for element [filtered]]]; }{[AS6HqxgNRtyU9-pQKhJsXQ][idx_occurrence][2]: SearchParseException[[idx_occurrence][2]: from[-1],size[-1]: Parse Failure [Failed to parse source [\\n{\\n filtered : {\\n query : {\\n term : { kingdom : Plantae }\\n }\\n}\\n}]]]; nested: SearchParseException[[idx_occurrence][2]: from[-1],size[-1]: Parse Failure [No parser for element [filtered]]]; }]","status":500} 错误:{“error”:“SearchPhaseExecutionException [无法执行阶段[查询],完全失败; shardFailures {[AS6HqxgNRtyU9-pQKhJsXQ] [idx_occurrence] [3]:SearchParseException [[idx_occurrence] [3]:from [-1], size [-1]:解析失败[无法解析源[\\ n {\\ n已过滤:{\\ n查询:{\\ n term:{kingdom:Plantae} \\ 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 filtered:{\\ n query:{\\ n term:{kingdom:Plantae}} \\ n} \\ n} \\ n}]]];嵌套:SearchParseException [[idx_occurrence] [2]:from [-1],size [-1]:Parse Failure [没有元素[filtered]的解析器]];} ]”, “状态”:500}

I have been using the Elastica PHP library for my elasticsearch interactions: 我一直在使用Elastica PHP库进行弹性搜索交互:

https://github.com/ruflin/Elastica https://github.com/ruflin/Elastica

It had a very short learning curve. 它的学习曲线很短。 Here's an example: 这是一个例子:

$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);

This illustrates a Query String search limited to a specific field. 这说明了限制于特定字段的查询字符串搜索。 $searchResults is an array of Elastica_ResultSet objects. $searchResults是一个Elastica_ResultSet对象的数组。 I like Elastica because it abstracts away any cURL-related issues. 我喜欢Elastica,因为它抽象出任何与cURL相关的问题。

this is a simple request demo: 这是一个简单的请求演示:

    $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;

I've found an answer myself to part of the question. 我自己找到了答案的一部分。 I managed to get it by command line. 我设法通过命令行获取它。

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

using PHP to execute the (correct) cURL request just sends back an empty string. 使用PHP执行(正确的)cURL请求只返回一个空字符串。 No errors in PHP logs. 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);

Again, if instead of this $url I send this url my_url:9200/idx_occurrence/Occurrence/_search?q=kingdom_interpreted:Plantae 再次,如果不是这个$ url我发送这个url my_url:9200 / idx_occurrence / Occurrence / _search?q = kingdom_interpreted:Plantae

It works. 有用。 Why? 为什么?

$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);

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM