Можно ли реализовать Live-поиск, используя AJAX и PHP по индексу эластичного поиска - PullRequest
0 голосов
/ 12 марта 2020

Я пытаюсь создать веб-приложение, используя PHP & AJAX. Он должен получать данные из Elasticsearch без обновления страницы (поиск в режиме реального времени). Можно ли реализовать такой поиск по индексу эластичного поиска? Для этого я сделал эти два файла: index2. php

<?php
    session_start();
?>

<html>
 <head>
  <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  <title>Ajax-Trials</title>
  <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.3/jquery.min.js"></script>
  <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/js/bootstrap.min.js"></script>
  <link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.min.css" rel="stylesheet" />
 </head>
 <body>
  <div class="container">
   <br />
   <h2 align="center">Ajax Live Data Search using Jquery, PHP, Elasticsearch</h2><br />
   <div class="form-group">
    <div class="input-group">
     <span class="input-group-addon">Search</span>
     <input type="text" name="search_text" id="search_text" placeholder="Search by Customer Details" class="form-control" />

    </div>
   </div>
   <br />
   <div id="result"></div>
  </div>
 </body>
</html>


<script>
$(document).ready(function(){

 load_data();

 function load_data(query)
 {
  $.ajax({
   url:"fetch2.php",
   method:"POST",
   data:{query:query},
   success:function(data)
   {
    $('#result').html(data);
   }
  });
 }
 $('#search_text').keyup(function(){
  var search = $(this).val();
  if(search != '')
  {
   load_data(search);
  }
  else
  {
   load_data();
  }
 });
});
</script>

и вот fetch2. php

<?php    
session_start();    
require_once '../vendor/autoload.php';
use Elasticsearch\ClientBuilder;
$client = ClientBuilder::create()->setHosts(['127.0.0.1:9200'])->build();
$output = '';
if(isset($_POST["query"]))
{
 $search = $_POST["query"];
 $query = $client->search([
    'body' => [
      'query' => [
        'bool' => [
          'should' => [
            'multi_match' => [
              "fuzziness" => "AUTO",
              'fields' => ['district','countrycode','name','population'],
              'query' => $search
            ]
          ]
        ]
      ],
      'from' => 0,
      'size' => 100
    ]

  ]);

  if($query['hits']['total']>=1){
    $results = $query['hits']['hits'];
  }

}

if(isset($results))
{
 $output .= '
  <div class="table-responsive">
   <table class="table table bordered">
    <tr>
     <th>ID</th>
     <th>Name</th>
     <th>CountryCode</th>
     <th>District</th>
     <th>Population</th>
    </tr>
 ';
 foreach($results as $r)
 {
  $output .= '
   <tr>
    <td>'.$r['_id'].'</td>
    <td>'.$r['_source']['name'].'</td>
    <td>'.$r['_source']['countrycode'].'</td>
    <td>'.$r['_source']['district'].'</td>
    <td>'.$r['_source']['population'].'</td>
   </tr>
  ';
 }
 echo $output;
}
else
{
 echo 'Data Not Found';
}

?>

Когда я ищу любую строку, она успешно печатает заголовки таблицы, но не печатает данные. В чем здесь проблема? Формат индекса JSON такой:

{
  "_index": "cities",
  "_type": "city",
  "_id": "35",
  "_version": 1,
  "_score": 0,
  "_source": {
    "id": 35,
    "@timestamp": "2020-03-10T18:24:46.963Z",
    "@version": "1",
    "population": 2168000,
    "district": "Alger",
    "countrycode": "DZA",
    "name": "Alger"
  },
  "fields": {
    "@timestamp": [
      "2020-03-10T18:24:46.963Z"
    ]
  }
}

Ответы [ 2 ]

0 голосов
/ 16 апреля 2020

Я только что удалил поле «население» из полей поиска, и это сработало. Elasticsearch здесь не может искать числовой c ввод и числовое поле.

0 голосов
/ 13 марта 2020

Ваш JSON формат показывает, что возвращаемые данные являются объектом. Чтобы получить доступ к значениям объекта, введите следующий код:

foreach($results as $r)
{
 $output .= '
 <tr>
<td>'.$r->_id.'</td>
<td>'.$r->_source->name.'</td>
<td>'.$r->_source->countrycode.'</td>
<td>'.$r->_source->district.'</td>
<td>'.$r->_source->population.'</td>
</tr>
';
}

Как видите, я использовал -> (Объект) вместо [] (массив)

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...