尝试优化上传图片

时间:2019-05-10 16:59:34

标签: php image-optimization

我有一个带有几个文本输入和一个文件上传功能的表格。表单的效果很好,它可以将文件上传到预期的位置,并在数据库中添加对该文件的引用。

问题是图像很大。因此,我希望表单继续以完整尺寸上传图片,但我希望它还将优化版本也上传到一个单独的文件夹中,该文件夹可以作为缩略图显示在前端。

我正在尝试实现SWI-Prolog中的代码。

我使用的代码需要安装GD,根据我的主机,它是安装的。

这是在我的functions.php文件中:

 function compress_image($source_url, $destination_url, $quality) { // optimizes images

       $info = getimagesize($source_url);

        if ($info['mime'] == 'image/jpeg')
              $image = imagecreatefromjpeg($source_url);

        elseif ($info['mime'] == 'image/gif')
              $image = imagecreatefromgif($source_url);

      elseif ($info['mime'] == 'image/png')
              $image = imagecreatefrompng($source_url);

        imagejpeg($image, $destination_url, $quality);
    return $destination_url;
    }

这是我的表格/ php:

<?php

if(isset($_POST['create_post'])) {

    $portfolio_title = $_POST['portfolio_title'];
    $portfolio_tagline = $_POST['portfolio_tagline'];
    $portfolio_image = $_FILES['image']['name'];
    $portfolio_image_temp = $_FILES['image']['tmp_name'];

  move_uploaded_file($portfolio_image_temp, "../images/$portfolio_image");

    $src_url = '../images/$portfolio_image';
    $destination_url = '../images/thumbnails/$portfolio_image'; 

    compress_image($src_url, $destination_url, 60);

  $query = "INSERT INTO portfolio(portfolio_title, portfolio_tagline, portfolio_image) ";

  $query .= "VALUES('{$portfolio_title}','{$portfolio_tagline}','{$portfolio_image}' ) ";

  $create_post_query = mysqli_query($connection, $query);

  confirm($create_post_query);
};

?>

    <form action="" method="post" enctype="multipart/form-data">
        <!-- enctype is because we're uploading an image -->

        <div class="form-group">
            <label for="portfolio_title">Title</label>
            <input type="text" class="form-control" name="portfolio_title">
        </div>

        <div class="form-group">
            <label for="portfolio_tagline">Tagline</label>
            <input type="text" class="form-control" name="portfolio_tagline">
        </div>

        <div class="form-group">
            <label for="portfolio_image">Image</label>
            <input type="file" class="form-control" name="image">
        </div>

        <div class="form-group">
            <input type="submit" class="btn btn-primary" name="create_post" value="Publish">
        </div>

    </form>

我希望compress_image函数将新上传的图像作为$ src_image并将优化的文件保存在$ destination_url中,但是出现以下错误:

警告:getimagesize(../ images / $ portfolio_image):无法打开流:第15行的/home/playground/public_html/bootstrap-template/admin/functions.php中没有此类文件或目录

警告:imagejpeg()期望参数1为资源,在第26行的/home/playground/public_html/bootstrap-template/admin/functions.php中给出的值为空

0 个答案:

没有答案