我一直在搞乱我的搜索页面。我添加了mysqli_real_escape_string
and strip_tags
,据我所知,一切正常,应该是安全的。
我只是想在搜索表单中输入随机符号,看看是否仍然可以在这些安全措施到位的情况下找到我的所有数据库条目。一切都很好,除了当我搜索单引号 ( '
) 时。
这给了我“mysqli_num_rows() 期望参数 1 是 mysqli_result, boolean given”错误。有很多关于该错误的信息,我知道如何解决它(至少我是这么认为的)。但是,在这种特殊情况下,我不知道:/
编码:
ini_set('display_errors', 1);
$search = $_GET ['q'];
$conn = mysqli_connect("localhost", "root", "","release");
$search = mysqli_real_escape_string($conn, "$search");
$search = stripslashes(strip_tags(trim("$search")));
$query = mysqli_query($conn,"SELECT * FROM game WHERE game_name LIKE '%". $search ."%' ORDER BY game_release");
$count = mysqli_num_rows($query);