Codeigniter缩略图图像路径不能存储在MySql中

Posted

技术标签:

【中文标题】Codeigniter缩略图图像路径不能存储在MySql中【英文标题】:Codeigniter thumbnail image path can not be stored in MySql 【发布时间】:2015-02-17 07:46:48 【问题描述】:

我正在尝试使用 Codeigniter 制作一个简单的应用程序,我需要在 mysql 数据库中存储缩略图图像路径。图像连同缩略图版本正确上传到上传文件夹中,我可以在上传时将图像路径存储在我的数据库中,但我无法将缩略图图像路径存储在数据库中。我在控制器中试过这个:

$thumbnail= $this->resize($data['upload_data']['full_path'], $data['upload_data']  ['file_name']);
$thumbnail_path = './uploads/'. $thumbnail;
$newRow = array(
                    "title" => $this->input->post('title'),
                    "img_path" => $imgpath,
                    "thumbnail_path" => $thumbnail_path,
                    "post_body" => $this->input->post('post_body')
                    )

但它只在我的表的 thumbnail_path 列中存储“./uploads/”,而不是实际的缩略图路径。我希望它在哪里存储类似“./uploads/Lighthouse_thumb.jpg”的东西。我不知道如何获取缩略图图像的路径以将它们存储在数据库中。这是我的完整上传控制器:

  class Upload extends CI_Controller
  

function __construct()

    parent::__construct();
    $this->load->helper('form');    

function index() 

        $this->load->view('upload_form', array('error'=>''));
    

function do_upload() 
    $config['upload_path'] = './uploads/';
    $config['allowed_types'] = 'gif|jpg|png';
    $config['max_size'] = '1000';
    $config['max_width']  = '1024';
    $config['max_height']  = '768';

    $this->load->library('upload', $config);

    if (!$this->upload->do_upload()) 
        $error = array('error' => $this->upload->display_errors());
        $this->load->view('upload_form', $error);
     else 
        $image_data = $this->upload->data();
        $imgpath = './uploads/' . $image_data['file_name'];
        $data = array('upload_data'=>$this->upload->data());
        $thumbnail= $this->resize($data['upload_data']['full_path'], $data['upload_data']['file_name']);
        $thumbnail_path = './uploads/'. $thumbnail;
        $newRow = array(
                    "title" => $this->input->post('title'),
                    "img_path" => $imgpath,
                    "thumbnail_path" => $thumbnail_path,
                    "post_body" => $this->input->post('post_body')
                    );
            $this->load->model('postimage_path');
            $this->postimage_path->insert($newRow);
            $this->load->view('upload_success', $data);
    

    
function resize($path, $file) 
        $config['image_library'] = 'gd2';
        $config['source_image'] =  $path;
        $config['create_thumb'] = TRUE;
        $config['maintian_ratio'] = TRUE;
        $config['width'] = 100;
        $config['height'] = 100;
        $config['new_image'] = './uploads/' . $file;

        $this->load->library('image_lib', $config);
        $this->image_lib->resize();

    

【问题讨论】:

【参考方案1】:
$thumbnail_path = './uploads/'. $thumbnail;

所以thumbnail_path 只包含“./uploads/”:这告诉我们$thumbnail 是假的(或null 或空字符串等),这意味着resize 调用的返回值是错误的——看起来您希望它返回文件名。

function resize($path, $file) 
    $config['image_library'] = 'gd2';
    $config['source_image'] =  $path;
    $config['create_thumb'] = TRUE;
    $config['maintian_ratio'] = TRUE;
    $config['width'] = 100;
    $config['height'] = 100;
    $config['new_image'] = './uploads/' . $file;

    $this->load->library('image_lib', $config);
    $this->image_lib->resize();


resize 什么都不返回!而你没有分配给$thumbnail_path。那是你的问题。

您似乎只是从the CodeIgniter docs 复制了代码。来自上述文档(强调我的):

上面的代码告诉 image_resize 函数在 source_image 文件夹中查找名为 mypic.jpg 的图像,然后使用 GD2 image_library 创建一个 75 X 50 像素的缩略图。由于启用了maintain_ratio 选项,拇指将尽可能接近目标宽度和高度,同时保留原始纵横比。 缩略图将被称为 mypic_thumb.jpg

所以你有它!如果您的文件名是$data['upload_data']['file_name'],您的缩略图将是$data['upload_data']['file_name'] . "_thumb"。查看您的文件系统,文件应该在那里供您查看。

所以要解决你的问题,这应该可以解决问题:

 $pathinfo = pathinfo($data['upload_data']['file_name']);
 $thumbnail_path = './uploads/'. $data['upload_data']['file_name'] . "_thumb" . $pathinfo['extension'];

【讨论】:

我如何从调整大小功能中获取新创建的图像拇指版本的路径。我怎样才能让它返回路径?有什么办法吗?我试过你的方法。它试图在数据库中插入这样的东西。 [插入posttitleimg_paththumbnail_pathpost_body)值('Hello world','./uploads/Tulips.jpg','./uploads/Tulips.jpg_thumbjpg', '我爱 php')]. 我已经检查过了。查看拇指版图片路径错误。因为调整大小功能将拇指创建为 "Tulips_thumb.jpg" ,但它存储了其他东西。可能通过一些实验,我可以存储拇指版本的路径,而不是来自 resize 函数,而是使用 pathinfo 函数。不过我得到了一些提示。我正在做。您的任何进一步帮助将不胜感激。谢谢 是的,我已经能够将缩略图的路径存储在数据库中,只需稍微修改一下您的方式。我用过这个:$thumbnail_path = './uploads/'。 $data['upload_data']['raw_name'] 。 “_拇指”。 “。” . $pathinfo['extension'];现在它可以成功存储缩略图的实际路径。再次感谢你。祝你幸福! 很高兴能帮到你!

以上是关于Codeigniter缩略图图像路径不能存储在MySql中的主要内容,如果未能解决你的问题,请参考以下文章

在 S3 中使用带有外部存储的图像和缩略图进行数据库设计的最佳实践?

Codeigniter 图像处理问题 [关闭]

将图像上载到CodeIgniter中的另一个目录

Firebase 图像存储 - 缩略图

等距画廊图像缩略图

如何在视频上传时创建缩略图? [php/codeigniter]