gpt4 book ai didi

php - 为什么包含在我的 PHP 文件中不包括我的变量?

转载 作者:行者123 更新时间:2023-11-30 00:59:38 25 4
gpt4 key购买 nike

我的 Android 应用程序中有 3 个 php 文件 - dbConnect.php,用于连接数据库,volleyLogin.php,用于登录用户,以及 UserDetails.php,获取有关登录用户的一些信息。

在我的浏览器中运行文件时,它们可以完美运行,但从我的 Android 应用程序运行时,UserDetails.php 无法运行。它一直返回“0 个结果”,我被告知变量 username 未定义,即使我使用 include 语句应该将一个 PHP 文件的内容插入另一个PHP 文件。

我的 dbConnect.php 看起来像这样:

<?php

define ('HOST', 'localhost');
define ('USER', 'root');
define ('PASS', 'password');
define ('DB', 'dbname');

$con = mysqli_connect("localhost", "root", "password", "dbname") or die('Unable to Connect');

?>

我的 volleyLogin.php 是这样的:

<?php

if($_SERVER['REQUEST_METHOD']=='POST'){
$username = $_POST['username'];

include('dbConnect.php');
$sql = "SELECT * FROM user WHERE username = '$username'";
$result = mysqli_query($con,$sql);
$check = mysqli_fetch_array($result);
if(isset($check)){

echo 'success';
} else {
echo 'Could not log in';
}
}

?>

UserDetails.php 看起来像这样:

<?php
include('dbConnect.php');
include('volleyLogin.php');

$resultSet = $con->query("SELECT category.cat_name FROM category INNER JOIN user ON category.user_id =
user.user_id WHERE user.username = '$username' ")

or die($con->error);

if ($resultSet->num_rows > 0) {

while($rows = $resultSet->fetch_assoc()) {

$catname = $rows['cat_name'];

echo "<p> Name: $catname </p>";
}}
else {
echo "0 results";
}
//echo "userdetails.php works";

$con->close();

?>

问题行是:

$resultSet = $con->query("SELECT category.cat_name FROM category INNER JOIN user ON category.user_id =
user.user_id WHERE user.username = '$username' ")

最佳答案

您的逻辑是错误的:mysqli_*() 函数基本上要么返回一个对象/结果句柄,要么返回一个 bool 值 true(成功)/false(失败)。他们总是返回一些东西,所以有:

$check = mysqli_fetch_array($result);
if(isset($check)){

错了。 $check 将始终被设置。您需要明确检查 bool 值 false 以检测失败:

if ($check === false) { 
die(mysqli_error($con));
}

请注意,在您的示例代码中您都没有定义 $username,因此您的查询正在执行 WHERE user.username = '',并且可能匹配 0

关于php - 为什么包含在我的 PHP 文件中不包括我的变量?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39603956/

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