很多開發中,我們試圖使用header("Content-type: image/jpeg");來 輸出圖片,試圖用一些php的圖像處理技術,讓輸出圖片更加智能和動感。但我們常常遇到新的問題,除非你規定不同的URL結構,並采用服務器技術將圖片緩 存,否則很有可能這些輸出圖片會消耗大量的流量。怎麼把它們緩存起來,下次用戶訪問的時候調用緩存呢?(前提是你的這個圖片希望保持不變)
代碼如下 // put this above any php image generation code:在header("Content-type: image/jpeg");上方添加上面這段代碼,它將規定當前頁面緩存的時間(兩天),並在下一次訪問中使用這個緩存時間節點。
接下來判斷是否已經有緩存,如果有,就使用緩存。
情況一:如果浏覽器對當前頁面已經有緩存,那麼就直接使用它。
代碼如下 // the browser will send a $_SERVER['HTTP_IF_MODIFIED_SINCE'] if it has a cached copy情況二:浏覽器緩存了當前頁,雖然我們更新了某些圖片信息,但來源圖片本身沒有變化,而且我們希望使用之前的緩存,那麼也使用緩存。
代碼如下$img = "some_image.png";
if (isset($_SERVER['HTTP_IF_MODIFIED_SINCE'])
&&
(strtotime($_SERVER['HTTP_IF_MODIFIED_SINCE']) == filemtime($img))) {
// send the last mod time of the file back
header('Last-Modified: '.gmdate('D, d M Y H:i:s', filemtime($img)).' GMT',
true, 304);
exit;
}
當然,有些特殊的情況我們還必須考慮,但上面的代碼基本上能夠帶領我們的思路。對了,記得把它們都放在header("Content-type: image/jpeg")的上面。
接著我們來看個例子吧
代碼如下<?php
//調整圖片大小
/**
*圖片按比例調整大小的原理:
*1、比較原圖大小是否小於等於目標大小,如果是則直接采用原圖寬高
*2、如果原圖大小超過目標大小,則對比原圖寬高大小
*3、如:寬>高,則寬=目標寬, 高=目標寬的比例 * 原高
*4、如:高>寬,則高=目標高,寬=目標高的比例 * 原寬
**/
$image = "test.jpg";
$max_width = 200;
$max_height = 200;
$size = getimagesize($image); //得到圖像的大小
$width = $size[0];
$height = $size[1];
$x_ratio = $max_width / $width;
$y_ratio = $max_height / $height;
if (($width <= $max_width) && ($height <= $max_height))
{
$tn_width = $width;
$tn_height = $height;
}
elseif (($x_ratio * $height) < $max_height)
{
$tn_height = ceil($x_ratio * $height);
$tn_width = $max_width;
}
else
{
$tn_width = ceil($y_ratio * $width);
$tn_height = $max_height;
}
$src = imagecreatefromjpeg($image);
$dst = imagecreatetruecolor($tn_width, $tn_height); //新建一個真彩色圖像
imagecopyresampled($dst, $src, 0, 0, 0, 0,
$tn_width, $tn_height, $width, $height); //重采樣拷貝部分圖像並調整大小
header('Content-Type: image/jpeg');
imagejpeg($dst,null,100);
imagedestroy($src);
imagedestroy($dst);
?>