Загрузка файла 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 ответ:
Ваш
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