0

如果要上传的图像超过 1mb,我需要知道如何处理此代码以减小/压缩要上传的图像的大小。

<form enctype="multipart/form-data" action='upcomg.php' method="post" name="changer">
<input name="MAX_FILE_SIZE" value="83886080" type="hidden">
<label>Please choose a file:</label><input name="image" accept="image/jpeg" type="file">
<input value="Submit" type="submit">

<?php
    if (isset($_FILES['image']) && $_FILES['image']['size'] > 0) {

    $tmpName = $_FILES['image']['tmp_name'];

    $fp = fopen($tmpName, 'r');
    $data = fread($fp, filesize($tmpName));
    $data = addslashes($data);
    fclose($fp);


    $query = "INSERT INTO ### ";
    $query .= "(##) VALUES ('$data')";
    $results = mysql_query($query, $link);

    // Print results
    print "Thank you, your file has been uploaded.";

    }
    else {
    print "No image selected/uploaded";
    }

    // Close our MySQL Link
    mysql_close($link);
?> 
4

1 回答 1

1

首先,我不会将原始图像数据存储在数据库中。将其存储在常规的旧静态文件中会更快,并且如果您的数据库脱机,也不会中断。

但话虽如此,你可以在里面放这样的东西:

$file = $_FILES['image']['tmp_name'];
if ( $_FILES['image']['size'] > 1024*1024 )
    $file = compress($file);

你已经有压缩方法了吗?如果不是,我也可以帮助你,但你可能想看看Imagick,因为它已经内置了压缩功能。

于 2013-07-14T20:15:08.780 回答