2

语境

  • 我正在为Motherpipe.co.uk的搜索引擎添加自动完成功能。
  • 我希望它只建议以用户输入的字母开头的术语。例如,如果用户键入“lon”,该函数应返回十个以“lon”开头的建议。
  • 我在本地数据库中有大约 50,000 个术语
  • 我已经设法让自动完成功能启动并运行,使用调用数据库(sql)的单独 php 脚本。

问题

我的问题是,无论用户输入什么,都会显示数据库中的前十个列表(基于 id)。只有在用户输入另一个字母后,建议才会正确显示。

问题

如何修改 jquery 或 php 代码以确保仅返回以输入内容开头的术语(然后仅返回该子集中基于 id 的前十个术语。)?

HTML

<script type="text/javascript" src="/scripts/autocomplete/autocomplete/jquery.js"></script>
<script type="text/javascript" src="/scripts/autocomplete/autocomplete/jquery.autocomplete.js"></script>
<script>
$(document).ready(function(){
 $("#tag").autocomplete("/scripts/autocomplete/autocomplete/autocomplete.php",  {
        selectFirst: false,
        minChars: 2
    });
});
</script>

PHP

<?php
    $q=$_GET['q'];
    $mydata=mysql_real_escape_string($q);
    $mysqli=mysqli_connect('localhost','username','password','languages') or die("Database Error");
    $sql="SELECT searchterms FROM topterms WHERE searchterms LIKE '$mydata%' ORDER by id";
    $result = mysqli_query($mysqli,$sql) or die(mysqli_error());

    if($result)
    {
        while($row=mysqli_fetch_array($result))
        {
            echo $row['searchterms']."\n";
        }
    }
?>
4

1 回答 1

0

当您使用 URL 作为源时,使用新版本的 jQuery 自动完成功能(就像您一样):

  1. 您必须返回 JSON 数据:

    字符串:使用字符串时,自动完成插件期望该字符串指向将返回 JSON 数据的 URL 资源。它可以在同一台主机上,也可以在不同的主机上(必须提供 JSONP)。

  2. 您收到的 GET 参数是 'term',而不是 'q'

    自动完成插件不过滤结果,而是添加了一个带有术语字段的查询字符串,服务器端脚本应该使用它来过滤结果。

  3. 在 PHP 中使用 mySQL 进行真正转义的正确方法是在建立连接后使用它,在您的情况下:

    $q = $_GET['term'];
    $mysqli = mysqli_connect('localhost','username','password','languages');
    if (!$mysqli or $mysqli->connect_error) die("Database Error");
    $mydata = $mysqli->real_escape_string($q);
    $sql = "SELECT searchterms FROM topterms WHERE searchterms LIKE '$mydata%' ORDER by id";
    $result = mysqli_query($mysqli,$sql);
    $json = array();
    if ($result and $result->num_rows > 0) {
        while($row=mysqli_fetch_array($result)) {
           $json[] = $row['searchterms'];
        }
    }
    header('Content-Type: application/json'); // You can skip that because IE doesn't really like it
    echo json_encode($json);
    
于 2013-08-13T18:29:10.387 回答