您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關php圖像裁剪服務器搭建的方法的內容。小編覺得挺實用的,因此分享給大家做個參考。一起跟隨小編過來看看吧。
在我們的工作的項目中,有時候我們需要顯示規定尺寸的圖片,雖然可以通過css來控制顯示大小。但是如果圖片過大,會造成加載的延遲,影響網站整體性能。因此,我們需要一個服務器來幫助我們進行圖片的裁剪。流程大致是,首先我們傳給服務器原圖像和裁剪的尺寸,然后服務器進行裁剪,生成對應的裁剪圖片,下次我們再訪問相同圖像和相同的裁剪尺寸的時候,我們就不需要裁剪,直接進行圖片的訪問就行。
Talk is cheap, show me the code.
<?php // ①構建圖片請求地址比如 https://cache.yisu.com/upload/information/20200318/98/35720.jpg // ②配置nginx重寫規則 rewrite /s/(.*)/(\d+)x(\d+)-(\d)/(.*) /s/resize.php?site=$1&width=$2&height=$3&mode=$4&path=$5 last; //③進行裁剪圖片的處理 $path = trim($_GET['path']); $mode = intval($_GET['mode']); $site = trim($_GET['site']); $width = intval($_GET['width']); $height = intval($_GET['height']); $site_list = array('crop' => '.'); $orig_dir = dirname(__FILE__); if (!array_key_exists($site, $site_list)) { header('HTTP/1.1 400 Bad Request'); exit(); } if ($mode > 3 || $mode < 0) { header('HTTP/1.1 400 Bad Request'); exit(); } $orig_file = $site_list[$site] . $path; if (!file_exists($orig_file)) { header('HTTP/1.1 404 Not Found'); exit(); } $file_ext = '.' . pathinfo($path, PATHINFO_EXTENSION); $file_name = basename($path, $file_ext); $save_path = "{$orig_dir}/{$site}/{$width}x{$height}-{$mode}{$path}"; $save_dir = dirname($save_path); if (!file_exists($save_dir)) { wpx_mkdir($save_dir); } $target_width = $width; $target_height = $height; $save_image = $save_dir . '/' . $file_name . '.jpg'; if (file_exists($save_image)) { header('Content-Type: image/jpeg'); header('Last-Modified: ' . gmdate('D, d M Y H:i:s') . ' GMT'); echo file_get_contents($save_image); } imagecropper2($orig_file, $target_width, $target_height, $save_image); die; //原圖像對應縮放裁剪,會拉伸圖片 function imagecropper2($source_path, $width, $height, $save_image) { //獲取原圖像$filename的寬度$width_orig和高度$height_orig $info = getimagesize($source_path); $width_orig = $info[0]; $height_orig = $info[1]; $mime = $info['mime']; //根據參數$width和$height值,換算出等比例縮放的高度和寬度 if ($width && ($width_orig<$height_orig)){ $width = ($height/$height_orig)*$width_orig; }else{ $height = ($width / $width_orig)*$height_orig; } //將原圖縮放到這個新創建的圖片資源中 $image_p = imagecreatetruecolor($width, $height); //獲取原圖的圖像資源 if($mime=='image/jpeg'){ $image = imagecreatefromjpeg($source_path); }elseif($mime=='image/png'){ $image = imagecreatefrompng($source_path); }elseif($mime=='image/gif'){ $image = imagecreatefromgif($source_path); } //使用imagecopyresampled()函數進行縮放設置 imagecopyresampled($image_p,$image,0,0,0,0,$width,$height,$width_orig,$height_orig); //將縮放后的圖片$image_p保存,100(質量最佳,文件最大) if($mime=='image/jpeg'){ imagejpeg($image_p,$save_image); header('Content-Type: image/jpeg'); imagejpeg($image_p); }elseif($mime=='image/png'){ imagepng($image_p,$save_image); header('Content-Type: image/jpeg'); imagepng($image_p); }else{ imagegif($image_p,$save_image); header('Content-Type: image/jpeg'); imagegif($image_p); } } //進行比例保存裁剪,會丟失圖像部分像素 function imagecropper($source_path, $target_width, $target_height, $save_image) { $source_info = getimagesize($source_path); $source_width = $source_info[0]; $source_height = $source_info[1]; $source_mime = $source_info['mime']; $source_ratio = $source_height / $source_width; $target_ratio = $target_height / $target_width; // 源圖過高 if ($source_ratio > $target_ratio) { $cropped_width = $source_width; $cropped_height = $source_width * $target_ratio; $source_x = 0; $source_y = ($source_height – $cropped_height) / 2; } // 源圖過寬 elseif ($source_ratio < $target_ratio) { $cropped_width = $source_height / $target_ratio; $cropped_height = $source_height; $source_x = ($source_width – $cropped_width) / 2; $source_y = 0; } // 源圖適中 else { $cropped_width = $source_width; $cropped_height = $source_height; $source_x = 0; $source_y = 0; } switch ($source_mime) { case 'image/gif': $source_image = imagecreatefromgif($source_path); break; case 'image/jpeg': $source_image = imagecreatefromjpeg($source_path); break; case 'image/png': $source_image = imagecreatefrompng($source_path); break; default: return false; break; } $target_image = imagecreatetruecolor($target_width, $target_height); $cropped_image = imagecreatetruecolor($cropped_width, $cropped_height); // 裁剪 $bool = imagecopy($cropped_image, $source_image, 0, 0, $source_x, $source_y, $cropped_width, $cropped_height); // 縮放 $bool = imagecopyresampled($target_image, $cropped_image, 0, 0, 0, 0, $target_width, $target_height, $cropped_width, $cropped_height); imagejpeg($target_image, $save_image); header('Content-Type: image/jpeg'); imagejpeg($target_image); imagedestroy($source_image); imagedestroy($target_image); imagedestroy($cropped_image); } // 循環生成目錄 function wpx_mkdir($dir, $mode = 0777) { if (is_dir($dir) || @mkdir($dir, $mode)) { return true; } if (!wpx_mkdir(dirname($dir), $mode)) { return false; } return @mkdir($dir, $mode); }
通過上面的處理,我們就將圖片按照我們設置的尺寸進行了裁剪。我們還可以定期對裁剪圖片進行清理,這樣就不需要占用太多服務器空間。只有經常訪問的圖片才會一直保存。
感謝各位的閱讀!關于php圖像裁剪服務器搭建的方法就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。