0

我有一个这样的脚本,它在我的模型中包含一个用于处理图像上传的脚本。然后我使用 addImage() 在该文件中调用一个函数,如下所示:

<?php
    include '../model/imageUploadHandler.php';

    $imgTitle = $_POST["image_title"];
    $imgDescr = $_POST["image_description"];
    $target_path = "../images/";
    $filename = basename( $_FILES['file']['name']);
    $target_path = $target_path . $filename;

    addImage($imgTitle, $imgDescr, $filename); 

?>

然后,在 imageUploadHandler.php 中,我编写了函数,该函数被顺利调用:

<?php
    include('./db_conn.php');

    function addImage($title, $description, $target_path)
    {
        if(move_uploaded_file($_FILES['file']['tmp_name'], $target_path))
        {
            $sql = "INSERT INTO image_data (filename, title, description) VALUES ('$target_path','$title','$description')";
            echo $sql;

            if (!mysqli_query($con, $sql))
            {
                die('Error: ' . mysqli_error());
            }
            echo "1 record added";

            echo "The file " .  basename( $_FILES['file']['name']) . " has been uploaded";
            echo $title;
            echo $description;
        }
        else
        {
            echo "There was an error uploading the file, please try again!";
        }
    }
?>

我已经包含了一个“db_conn.php”脚本,这样我就可以在需要连接到数据库的任何地方包含 db_conn.php。这是 db_conn.php

<?php
    // Create connection
    $con = mysqli_connect("","root","root", "image_info");

    // Check connection
    if (mysqli_connect_errno($con))
    {
        echo "Failed to connect to MySQL: " . mysqli_connect_error();
    }
?>

如果我将连接脚本直接内联而不包含包含,则数据库已连接并且一切正常。但是,当我尝试包含外部文件 (db_conn.php) 时,由于某种原因,$con 变量对我的 imageUploadHandler.php 不可用

任何想法为什么?

4

1 回答 1

1

这是一个范围问题。除非作为参数传入或声明,否则global您的连接将在您的函数范围内不可用。

于 2013-03-07T16:38:54.437 回答