显示数据库中路径中的图像


Display image from path in database

我想显示我上传的图像并将图像的路径保存在MySQL数据库中。

以下是我用于上传图像并将表的路径保存在数据库中的所有代码:

网页表单:

<!DOCTYPE html>
<html>
<body>

<form action="processfangstrapport.php" enctype="multipart/form-data" method="post">
<table style="border-collapse: collapse; font: 12px Tahoma;" border="1" cellspacing="5" cellpadding="5">
<tbody><tr>
<td>
<input name="billed1" type="file" accept="image/jpeg">
</td>
</tr>
<tr>
<td>
<input name="Upload Now" type="submit" value="Upload Image">
</td>
</tr>
</tbody></table>
</form>
</body>
</html>

我的进程 php:

$servername = "localhost";
$username = "root";
$password = "";
$dbname = "fiskerirapporter";
//Opretter forbindelse til databasen
$conn = new mysqli($servername, $username, $password, $dbname);
//Check forbindelse
if ($conn->connect_error) {
    die("Forbindelse mislykkedes: " . $conn->connect_error);
}
    function GetImageExtension($imagetype)
     {
       if(empty($imagetype)) return false;
       switch($imagetype)
       {
           case 'image/bmp': return '.bmp';
           case 'image/gif': return '.gif';
           case 'image/jpeg': return '.jpg';
           case 'image/png': return '.png';
           default: return false;
       }
     }
if (!empty($_FILES["billed1"]["name"])) {
    $file_name=$_FILES["billed1"]["name"];
    $temp_name=$_FILES["billed1"]["tmp_name"];
    $imgtype=$_FILES["billed1"]["type"];
    $ext= GetImageExtension($imgtype);
    $imagename=date("d-m-Y")."-".time().$ext;
    $target_path = "images/".$imagename;
if(move_uploaded_file($temp_name, $target_path)) {
    $query_upload="INSERT into images_tbl (images_path,submission_date) VALUES 
('".$target_path."','".date("Y-m-d")."')";
    mysqli_query($conn, $query_upload) or die("error in $query_upload == ----> ".mysql_error());  
}else{
   exit("Error While uploading image on the server");
} 
echo "Din fangstrapport er nu oprettet.";
}
$conn->close();
?>

以及我的数据库表的结构:

CREATE TABLE images_tbl(
id INT NOT NULL AUTO_INCREMENT unique,
images_path VARCHAR(200) NOT NULL,
submission_date DATE
);
为此,

您需要做的就是从数据库中获取所需的路径,并在 HTML 图像标记中使用该路径src

echo '<img src="$imagePathFromDatabase" ... >';

要从数据库中获取图像,我们只需要通过查询SELECT它,类似于:

SELECT images_path FROM images_tbl WHERE images_path='imagePathYouWant' LIMIT 1;

将表数据加载到$result,并根据需要对以下查询进行修改。

    foreach ($result as $value){
     $path = 'http://address-upto-the-image-directory/'.$value[imagepath];
     echo "<img src='".$path."' />";
    }

此处imagepath是您在表中存储路径的字段名称。