簡體   English   中英

如何從數據庫顯示BLOB圖像?

[英]How to Display a BLOB Image from database?

我知道在同一主題上有幾個問題,但是沒有一個問題真正解決了我的問題。 我嘗試了以下問題的解決方法:

但是每種方法都會導致相同的結果。 我得到這種東西而不是圖像: 在此處輸入圖片說明 我用於數據庫連接的代碼對於插入是相同的,並且我可以成功插入圖像,只要它們沒有顯示即可。 我仍然粘貼我的代碼以防它們相關:

連接字符串:

  $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);
    }
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM