gpt4 book ai didi

php - 在实时 ajax 搜索中搜索时出现 fatal error

转载 作者:行者123 更新时间:2023-11-29 12:34:12 25 4
gpt4 key购买 nike

我正在使用实时 AJAX 搜索我的网站。

我从 nineto Five.me/data/tutorials/live-search/ 下载了脚本。

当我搜索时,出现 fatal error :第 54 行在 E:\xampp\htdocs\test\ajaxsearch\search.php 中的非对象上调用成员函数 fetch_array() .

除了更改 MySQL 凭据之外,我没有对演示脚本进行任何更改。

这是我的 search.php:

<?php
// Credentials
$dbhost = "localhost";
$dbname = "testdb";
$dbuser = "root";
$dbpass = "";

// Connection
global $tutorial_db;

$tutorial_db = new mysqli();
$tutorial_db->connect($dbhost, $dbuser, $dbpass, $dbname);
$tutorial_db->set_charset("utf8");

// Check Connection
if ($tutorial_db->connect_errno) {
printf("Connect failed: %s\n", $tutorial_db->connect_error);
exit();
}

/************************************************
Search Functionality
************************************************/

// Define Output HTML Formating
$html = '';
$html .= '<li class="result">';
$html .= '<a target="_blank" href="urlString">';
$html .= '<h3>nameString</h3>';
$html .= '<h4>functionString</h4>';
$html .= '</a>';
$html .= '</li>';

// Get Search
$search_string = preg_replace("/[^A-Za-z0-9]/", " ", $_POST['query']);
$search_string = $tutorial_db->real_escape_string($search_string);

// Check Length More Than One Character
if (strlen($search_string) >= 1 && $search_string !== ' ') {
// Build Query
$query = 'SELECT * FROM search WHERE function LIKE "%'.$search_string.'%" OR name LIKE "%'.$search_string.'%"';

// Do Search
$result = $tutorial_db->query($query);
while($results = $result->fetch_array()) {
$result_array[] = $results;
}
// Check If We Have Results
if (isset($result_array)) {
foreach ($result_array as $result) {
// Format Output Strings And Hightlight Matches
$display_function = preg_replace("/".$search_string."/i", "<b class='highlight'>".$search_string."</b>", $result['function']);
$display_name = preg_replace("/".$search_string."/i", "<b class='highlight'>".$search_string."</b>", $result['name']);
$display_url = 'http://php.net/manual-lookup.php?pattern='.urlencode($result['function']).'&lang=en';

// Insert Name
$output = str_replace('nameString', $display_name, $html);

// Insert Function
$output = str_replace('functionString', $display_function, $output);

// Insert URL
$output = str_replace('urlString', $display_url, $output);

// Output
echo($output);
}
}else{

// Format No Results Output
$output = str_replace('urlString', 'javascript:void(0);', $html);
$output = str_replace('nameString', '<b>No Results Found.</b>', $output);
$output = str_replace('functionString', 'Sorry :(', $output);

// Output
echo($output);
}
}


/*
// Build Function List (Insert All Functions Into DB - From PHP)

// Compile Functions Array
$functions = get_defined_functions();
$functions = $functions['internal'];

// Loop, Format and Insert
foreach ($functions as $function) {
$function_name = str_replace("_", " ", $function);
$function_name = ucwords($function_name);

$query = '';
$query = 'INSERT INTO search SET id = "", function = "'.$function.'", name = "'.$function_name.'"';

$tutorial_db->query($query);
}
*/
?>

请帮助我:

最佳答案

在使用之前,您必须检查 mysqli->query 方法返回的内容。

如果您的 SQL 查询中有错误,查询方法应返回FALSE,在这种情况下,您可以询问 myslqi 有什么错误错误属性。

你的代码应该是这样的:

$result = $tutorial_db->query($query);
if($result === FALSE) {
echo $tutorial_db->error;
// or do whatever you have to do to fix or log the issue.
}
else {
while($results = $result->fetch_array()) {
$result_array[] = $results;
}
}

关于php - 在实时 ajax 搜索中搜索时出现 fatal error ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27040267/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com