ホームページ > バックエンド開発 > PHPチュートリアル > PHPはサーバー側で画像サイズ調整を実装します

PHPはサーバー側で画像サイズ調整を実装します

墨辰丷
リリース: 2023-03-31 12:08:01
オリジナル
1497 人が閲覧しました

この記事ではサーバー側での画像サイズ調整のPHP実装を中心に紹介していますので、興味のある方は参考にしていただければ幸いです。

この記事の例では、PHP でサーバー側で画像サイズを調整する方法を説明します。具体的な分析は次のとおりです。

画像サイズの調整をサーバー側で完了すると、ブラウザで処理する場合に比べて多くの利点があります。
この記事では、PHP がサーバー側で画像のサイズを変更する方法を紹介します。

コードには 2 つの部分が含まれています:

① imageResizer() は画像を処理するために使用されます
②loadimage() はより単純な形式で画像 URL を挿入します

<?php
 function imageResizer($url, $width, $height) {
  header(&#39;Content-type: image/jpeg&#39;);
  list($width_orig, $height_orig) = getimagesize($url);
  $ratio_orig = $width_orig/$height_orig;
  if ($width/$height > $ratio_orig) {
   $width = $height*$ratio_orig;
  } else {
   $height = $width/$ratio_orig;
  }
  // This resamples the image
  $image_p = imagecreatetruecolor($width, $height);
  $image = imagecreatefromjpeg($url);
  imagecopyresampled($image_p, $image, 0, 0, 0, 0, $width, $height, $width_orig, $height_orig);
  // Output the image
  imagejpeg($image_p, null, 100);
 }
 //works with both POST and GET
 $method = $_SERVER[&#39;REQUEST_METHOD&#39;];
 if ($method == &#39;GET&#39;) {
  imageResize($_GET[&#39;url&#39;], $_GET[&#39;w&#39;], $_GET[&#39;h&#39;]);
  } elseif ($method == &#39;POST&#39;) {
  imageResize($_POST[&#39;url&#39;], $_POST[&#39;w&#39;], $_POST[&#39;h&#39;]);
  }
 // makes the process simpler
 function loadImage($url, $width, $height){
  echo &#39;image.php?url=&#39;, urlencode($url) ,
  &#39;&w=&#39;,$width,
  &#39;&h=&#39;,$height;
 }
?>
ログイン後にコピー

使用法:

//Above code would be in a file called image.php.
//Images would be displayed like this:
<img src="<?php loadImage(&#39;image.jpg&#39;, 50, 50) ?>" alt="" />
ログイン後にコピー

要約: 以上がこの記事の全内容です。皆さんの学習に役立つことを願っています。

関連する推奨事項:

PHP に基づいて特定の月の週次情報を取得する

php実装 テキスト メッセージを送受信するための関数

PHP セッション処理のための 10 の関数

以上がPHPはサーバー側で画像サイズ調整を実装しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート