Загрузка файла Codeigniter с phpmyadmin стала нечитаемой


Когда я загружаю файл из таблицы базы данных (пользователи), файл становится нечитаемым. Файл изображения станет недействительным, а файл PDF не будет загружен. Размер загруженного файла также станет 1 КБ.

Хотя сначала я успешно загрузил файл в ту же таблицу (пользователи), поэтому файл определенно не 1kb.

Таблица (пользователи)

Пример ошибки при открытии pdf файла

Мой Контроллер (Файлы.php)

<?php if ( ! defined('BASEPATH')) exit('No direct script access allowed');
class Files extends CI_Controller {
    
    function __construct() {
        parent::__construct();
        $this->load->model('user');
    }
    
    public function index(){
        $data = array();
        
        //get files from database
        $data['files'] = $this->user->getRows();
        
        //load the view
        $this->load->view('r_down', $data); //modell->view
    }
    
    public function download($id){
        if(!empty($id)){
            //load download helper
            $this->load->helper('download');
            
            //get file info from database
            $fileInfo = $this->user->getRows(array('id' => $id));
            
            //file path
            $file = 'uploads/files/'.$fileInfo['picture']; 
            //download file 
           force_download($file, '$data');//name file nk save
         //force_download($file,NULL);//name file nk save
        }
    }

Мой взгляд(r_down.php)

<?php if(!empty($files)){ foreach($files as $frow){ ?>
<div class="file-box">
    <div class="box-content">
        <h5><?php echo $frow['name']; ?></h5>
        <div class="preview">
            <embed src="<?php echo base_url().'uploads/images/'.$frow['picture']; ?>"> <!-- nk view apa letak dlm %frow, ikut nama column. directory ikut folder pc?-->
        </div>
        <a href="<?php echo base_url().'index.php/files/download/'.$frow['id']; ?>" class="dwn">Download</a>
    </div>
</div>
<?php } } ?>

Модель (файл.php)

function getRows($params = array()){
        $this->db->select('*');
        $this->db->from('users');
        $this->db->where('status','1');
        $this->db->order_by('created','email');
        if(array_key_exists('id',$params) && !empty($params['id'])){
            $this->db->where('id',$params['id']);
            //get records
            $query = $this->db->get();
            $result = ($query->num_rows() > 0)?$query->row_array():FALSE;
        }else{
            //set start and limit
            if(array_key_exists("start",$params) && array_key_exists("limit",$params)){
                $this->db->limit($params['limit'],$params['start']);
            }elseif(!array_key_exists("start",$params) && array_key_exists("limit",$params)){
                $this->db->limit($params['limit']);
            }
            //get records
            $query = $this->db->get();
            $result = ($query->num_rows() > 0)?$query->result_array():FALSE;
        }
        //return fetched data
        return $result;
    }
1 2

1 ответ:

Ваш download метод должен быть таким:

public function download($id)
{
  if(!empty($id))
  {
    $this->load->helper('download');
    $fileInfo = $this->user->getRows(array('id' => $id));
    $file = FCPATH.'uploads/files/'.$fileInfo['picture']; 
    force_download($file, NULL);
  }
}

Ваш взгляд должен быть таким:

<?php if(!empty($files)){ 
  foreach($files as $frow) { ?>
    <div class="file-box">
      <div class="box-content">
          <h5><?php echo $frow['name']; ?></h5>
          <div class="preview">
            <embed src="<?=site_url('uploads/images/'.$frow['picture']); ?>"> 
          </div>
          <a href="<?=site_url('files/download/'.$frow['id']);?>" class="dwn">Download</a>
      </div>
    </div>
<?php } } ?>

Подробнее: https://www.codeigniter.com/user_guide/helpers/download_helper.html