Программа-O Chatbot Автозаполнение

Я работаю над чат-программой Program-o и по большей части работает отлично.

  1. Я пытаюсь сделать автозаполнение поля ввода "сказать" на основе того, что бот уже знает из определений AIML.
  2. Моя проблема в том, что я не знаю, как работает их логика /SQL, чтобы определить, что возвращается, чтобы я мог построить SQL для функции автозаполнения.
  3. Я использую версию ChatBot для JSON / JQuery и не вносил никаких изменений в код. Были добавлены библиотеки CDN JQuery и JQuery UI (для автозаполнения JS). Код автозаполнения от Дэвида Карра.

Спасибо за любую помощь, которую вы можете предоставить!

//I added autocomplete JS within index.php

    $(function() {

        //autocomplete
        $(".auto").autocomplete({
            source: "search.php",
            minLength: 1
        });                

    });

//Search.php included within index.php

<?php
define('DB_SERVER', 'localhost');
define('DB_USER', 'root');
define('DB_PASSWORD', 'root');
define('DB_NAME', 'demo');

if (isset($_GET['say'])){
    $return_arr = array();

    try {
        $conn = new PDO("mysql:host=".DB_SERVER.";port=8889;dbname=".DB_NAME, DB_USER, DB_PASSWORD);
        $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

        $stmt = $conn->prepare('SELECT something FROM someTable WHERE something LIKE :say');
        $stmt->execute(array('term' => '%'.$_GET['term'].'%'));

        while($row = $stmt->fetch()) {
            $return_arr[] =  $row['something'];
        }

    } catch(PDOException $e) {
        echo 'ERROR: ' . $e->getMessage();
    }

    /* Toss back results as json encoded array. */
    echo json_encode($return_arr);
}

?>

1 ответ

Решение

Я не подходил к этой проблеме правильно. Вы можете сделать запрос, как показано ниже. Убедитесь, что вы включили jQuery UI CSS и JS файлы, чтобы это работало. Наконец, приведенный ниже скрипт не показывает саму форму, но гарантирует, что у вас есть ввод с id = "say" для правильной работы. Лучшие ответы приветствуются, но это то, что я смог придумать. Спасибо

//Main File / index.php etc
<script>
$(function() {
    $( "#say" ).autocomplete({
       source: "search.php",
       minLength: 1
    });
});
</script>


//search.php
<?php
$host="localhost";
$username="uid";
$password="pwd";
$dbname="name";

//create a connection with dbname
$conn=mysqli_connect($host,$username,$password,$dbname);
if(!$conn)
{
 die("error in establishing connection: ". mysqli_connect_error());
}

$search=$_GET['term'];

//select query to get data from table
$sql="SELECT pattern from aiml WHERE pattern LIKE '%".$search."%'";

//run the above query
$result=mysqli_query($conn,$sql);

//display all the records
while($row=mysqli_fetch_assoc($result))
{
 //storing all the values of 'post_title' field one by one in an array
 $data[]=$row['pattern'];
}

//return json data
echo json_encode($data);
?>
Другие вопросы по тегам