Программа-O Chatbot Автозаполнение
Я работаю над чат-программой Program-o и по большей части работает отлично.
- Я пытаюсь сделать автозаполнение поля ввода "сказать" на основе того, что бот уже знает из определений AIML.
- Моя проблема в том, что я не знаю, как работает их логика /SQL, чтобы определить, что возвращается, чтобы я мог построить SQL для функции автозаполнения.
- Я использую версию 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);
?>