<?php
$image = new Imagick('input.jpg'); // 入力画像ファイル
$image->setImageFormat('webp'); // 出力形式をwebpに設定
$image->setImageCompressionQuality(80); // 画像の品質を設定(0-100の範囲、高いほど品質が良い)
$image->writeImage('output.webp'); // 出力ファイル名
?>
if (extension_loaded('imagick')) {
echo 'Imagickを使用します。';
} elseif (extension_loaded('gd')) {
echo 'GDを使用します。';
} else {
echo 'ImagickもGDも利用できません。';
}
これは SVG ではありません。「href="data:image/png;base64,~"」は「データURLスキーム」と呼ばれるもので、画像データを直接HTMLやCSSに埋め込むための形式です。
この形式では、「data:」の後にメディアタイプ(この場合は「image/png」)、次にデータのエンコーディング(この場合は「base64」)、そして実際のエンコードされたデータ(この場合は「~」)が続きます。
したがって、このデータURLはPNG画像を表しています。SVGとは異なり、PNGはラスターグラフィックス形式で、ピクセルデータを直接エンコードします。一方、SVGはベクターグラフィックス形式で、画像を数学的な形状とパスで記述します。
/etc/php-fpm.d/www.conf で設定されているuserとgroup。
例えば、
user = apache
group = apache
サーバーのcronを使ってPHPファイルを実行する場合、そのPHPファイルの実行ユーザーはcronの実行ユーザーになります。つまり、cronジョブを設定したユーザー(例えば、rootや特定のシステムユーザーなど)の権限でPHPスクリプトが実行されます。
一方、Webサーバー(例えばApache)経由でPHPファイルを実行する場合、その実行ユーザーは通常、Webサーバーの実行ユーザー(例えば、www-dataやapacheなど)になります。
したがって、cronを使ってPHPを実行するときとWebサーバー経由でPHPを実行するときでは、実行ユーザーが異なる可能性があります。これはファイルの読み書き権限などに影響を与えるため、注意が必要です。
ディレクトリのパーミッションにおいて、「r」は「読み取り」を意味します。したがって、ディレクトリのパーミッションで「r」がない場合、そのディレクトリの内容を読み取ることができません。具体的には、ディレクトリ内のファイルやサブディレクトリの名前をリストすることができなくなります。
例えば、`ls` コマンドを使用してディレクトリの内容を表示しようとすると、「Permission denied」(許可が拒否されました)というエラーメッセージが表示されます。また、そのディレクトリ内のファイルを開くこともできません。
ただし、ディレクトリ自体に対する「実行」(x)パーミッションがある場合、そのディレクトリ内の特定のファイルにアクセスすることは可能です(そのファイルのパーミッションがそれを許可している場合)。しかし、「読み取り」(r)パーミッションがないため、どのファイルが存在するのかを知る方法はありません。
PHPでファイルを作成、編集、削除したいなら。
ディレクトリに「w」と「x」。ファイルに「w」が必要。
PHPでファイルを編集できればいいのなら。
ディレクトリに「x」。ファイルに「w」が必要。
なお、ファイルに「r」がないと、file_get_contentsで読み込めない。(ディレクトリに「x」は必要)
読み取り権限(R)の確認:
<?php
$file = 'example.txt';
if (is_readable($file)) {
echo "The file '$file' is readable.";
} else {
echo "The file '$file' is not readable.";
}
?>
書き込み権限(W)の確認:
<?php
$file = 'example.txt';
if (is_writable($file)) {
echo "The file '$file' is writable.";
} else {
echo "The file '$file' is not writable.";
}
?>
実行権限(X)の確認:
<?php
$file = 'example.txt';
if (is_executable($file)) {
echo "The file '$file' is executable.";
} else {
echo "The file '$file' is not executable.";
}
?>
ファイルの作成:
<?php
$file = 'example.txt';
$content = 'Hello, World!';
// ファイルを開く(存在しない場合は新規作成)
$handle = fopen($file, 'w');
if ($handle) {
// ファイルに書き込む
fwrite($handle, $content);
// ファイルを閉じる
fclose($handle);
echo "File '$file' has been created.";
} else {
echo "Unable to create the file '$file'.";
}
?>
ファイルの編集:
<?php
$file = 'example.txt';
$content = ' This is additional content.';
// ファイルを開く(追記モード)
$handle = fopen($file, 'a');
if ($handle) {
// ファイルに書き込む
fwrite($handle, $content);
// ファイルを閉じる
fclose($handle);
echo "File '$file' has been updated.";
} else {
echo "Unable to update the file '$file'.";
}
?>
ファイルの削除:
<?php
$file = 'example.txt';
// ファイルを削除
if (unlink($file)) {
echo "File '$file' has been deleted.";
} else {
echo "Unable to delete the file '$file'.";
}
?>
ディレクトリのパーミッション
R: ディレクトリ内のファイルが表示されるか(lsで表示されるか)
W: ディレクトリ内のファイルを新規作成, 消去できるか(存在するファイルの読み書きは可能)
X: ディレクトリ内に入れるか(cdできるか)
ファイルのパーミッション
R: ファイルを読み込むことができる。
W: ファイルを上書きできる。
X: ファイルを実行できる。