首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >PHP警告: mysqli::query():无法获取mysqli

PHP警告: mysqli::query():无法获取mysqli
EN

Stack Overflow用户
提问于 2016-10-19 00:25:10
回答 2查看 15.1K关注 0票数 1

下面是我当前的代码:

代码语言:javascript
复制
<?php 
$key = $_REQUEST['key'];
$url = $_REQUEST['url'];

include_once '../../dbconnect.php';

$query = $conn->query("SELECT * FROM members WHERE apikey='$key' && status='Active'");
$userRow=$query->fetch_array();
$conn->close();

/// Verify the URL starts with http:// or https://
if (0 === strpos($url, 'http://') || 0 === strpos($url, 'https://')) {
$url = $url;
} else {
$url = "http://$url";
}

/// Verify the key is 32 characters
if (!preg_match('/[^A-Za-z0-9]/', $key) && (strlen($key) == 32)) {

/// Verify the URL isn't malicious
if (filter_var($url, FILTER_VALIDATE_URL) === FALSE) {
    die('Error:  Invalid URL');
} else {

if ($userRow['status'] === 'Active') {

function generateRandomString($length = 8) {
    $characters = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
    $charactersLength = strlen($characters);
    $randomString = '';
    for ($i = 0; $i < $length; $i++) {
        $randomString .= $characters[rand(0, $charactersLength - 1)];
    }
    return $randomString;
}

$redirect = generateRandomString();

$addshort = $conn->query("INSERT INTO short_".$redirect[0]." (redirect, apikey, url) VALUES ('".$redirect."','".$key."','".$url."')");

if ($conn->query($addshort) === TRUE) {
echo "added correctly";
} else {
echo "there was an error";
}

$conn->close();

} else {
echo "Error:  Account Not Active";
}

}

} else {
die('Error:  Invalid API Key');
}
?>

下面是error_log:

代码语言:javascript
复制
[18-Oct-2016 12:21:31 America/New_York] PHP Warning:  mysqli::query(): Couldn't fetch mysqli in /home/username/public_html/subdomains/url/index.php on line 40
[18-Oct-2016 12:21:31 America/New_York] PHP Warning:  mysqli::query(): Empty query in /home/username/public_html/subdomains/url/index.php on line 42
[18-Oct-2016 12:21:31 America/New_York] PHP Warning:  mysqli::close(): Couldn't fetch mysqli in /home/username/public_html/subdomains/url/index.php on line 48

你可以在第7行看到我第一次连接到数据库的地方:

代码语言:javascript
复制
$query = $conn->query("SELECT * FROM members WHERE apikey='$key' && status='Active'");

这条线起作用了。然而,当我第二次连接到INSERT时,我得到了上面的错误:

代码语言:javascript
复制
$addshort = $conn->query("INSERT INTO short_".$redirect[0]." (redirect, apikey, url) VALUES ('".$redirect."','".$key."','".$url."')");

只是盯着这段代码看了太久,是不是遗漏了什么?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2016-10-19 00:30:36

您的连接已经关闭,执行第一条SELECT语句后,表示连接提前关闭:

代码语言:javascript
复制
$conn->close();

您需要在所有查询或重新建立连接后使用close()。第一个是更好的选择。

您正在获得用户输入$_REQUEST['key']__,这意味着您的查询是为SQL注入打开的,这将帮助您理解如何使用SQL注入阻止您的代码:。

票数 5
EN

Stack Overflow用户

发布于 2016-10-19 00:31:39

这一点:

代码语言:javascript
复制
$addshort = $conn->query("INSERT ...')");
^^^^^^^
if ($conn->query($addshort) === TRUE) {
                   ^^^^^

$addshort是您的查询结果/句柄/对象,然后您尝试再次执行,这是不起作用的。query()需要一个SQL字符串,而您传入的是一个对象。

最重要的是,你很容易受到sql injection attacks的攻击。

票数 -1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/40113437

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档