php - 如何显示数据库中的 BLOB 图像?

标签 php mysql database image blob

我知道有几个关于同一主题的问题,但它们都没有真正解决我的问题。我尝试过以下问题的方法:

但是每种方法都会产生相同的结果。我得到的是这样的东西而不是图像: 奥 git _a 我的数据库连接代码与插入相同,我可以成功插入图像,只是它们没有显示。我仍然粘贴我的代码,以防它们相关:

连接字符串:

	  $user = "root";
    $pass = "";
    $db = "raw_images";


	$conn = mysqli_connect('localhost',$user,$pass,$db);
	if(!$conn)
	{
		die(mysqli_error());
	}

显示代码:

echo '<img src="data:image/jpeg;base64,'.base64_encode( $result['image'] ).'"/>';

插入代码:

<!--HTML Form-->

<form action="" method="POST" enctype="multipart/form-data">
    <input type="file" name="files[]" multiple class="Box"/>
    <input type="submit" class="Default"/>
</form>

<!--PHP Code-->

$imageData = array();
if(isset($_FILES['files'])){
    $errors= array();
	foreach($_FILES['files']['tmp_name'] as $key => $tmp_name ){
		$file_name = $key.$_FILES['files']['name'][$key];
		$file_tmp =$_FILES['files']['tmp_name'][$key];

        array_push($imageData, $file_name);

        $desired_dir="user_data";
        if(empty($errors)==true){
            if(is_dir($desired_dir)==false){
                mkdir("$desired_dir", 0700);		// Create directory if it does not exist
            }
            if(is_dir("$desired_dir/".$file_name)==false){
                move_uploaded_file($file_tmp,"user_data/".$file_name);
            }else{									//rename the file if another one exist
                $new_dir="user_data/".$file_name.time();
                 rename($file_tmp,$new_dir) ;
            }

        }else{
                print_r($errors);
        }

	if(empty($error)){

		$imgDt = implode("|", $imageData);
		$query="INSERT INTO tbl_raw_image (image) VALUES('$imgDt'); ";
		$rs  = mysqli_query($conn, $query);
    $imageData = array();
	}
}

}

最佳答案

您忘记获取正确的原始数据。请注意这一行:

$blobimage = addslashes(file_get_contents($_FILES['files']['tmp_name'][$key]));


foreach($_FILES['files']['tmp_name'] as $key => $tmp_name ){
        $blobimage = addslashes(file_get_contents($_FILES['files']['tmp_name'][$key]));
        $filename = $_FILES['files']['name'][$key];
        $path = $_FILES['files']['name'][$key];
        $ext = pathinfo($path, PATHINFO_EXTENSION);
        $desired_dir="upload/";
        if(empty($errors)==true){
            if(is_dir($desired_dir)==false){
                mkdir("$desired_dir", 0700);        // Create directory if it does not exist
            }
            if(is_dir("$desired_dir".$filename.'.'.$ext)==false){
                move_uploaded_file($_FILES['files']['tmp_name'][$key], $desired_dir.$filename.'.'.$ext);
            }else{          
                $new_dir=$desired_dir.$filename.'.'.$ext.time();
                rename($desired_dir.$filename.'.'.$ext,$new_dir) ;
            }            

        }else{
                print_r($errors);
        }

    if(empty($error)){
        $query="INSERT INTO tbl_raw_image (image) VALUES('$blobimage'); ";
        $rs  = mysqli_query($conn, $query);
    }
}

关于php - 如何显示数据库中的 BLOB 图像?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50898288/

相关文章:

php - 无效参数编号 : no parameters were bound

php - 使用ajax调用从服务器文件夹下载图像

mysql创建 View 报错1052

php - 从自定义 WordPress 数据库表返回图像 (LONGBLOB)

php - 在mysql中本地和在线运行相同的数据库

database - 检查 typo3 网站的数据库

php - 从 PHP 切换到 Rails 需要帮助翻译 URL 缩短器

php - mysql 在开始和/或结束时不断删除零

MySQL SELECT DISTINCT 与多个 JOINS

database - Navicat 无法使用 PostgreSQL 数据库