ホームページ >バックエンド開発 >PHPチュートリアル >PHP が UTF-8 ファイル BOM の自動検出と削除を実装する例、_PHP チュートリアル
この記事の例では、PHP で UTF-8 ファイル BOM の自動検出と削除を実装する方法を説明します。参考のためにみんなで共有してください。具体的な実装方法は以下の通りです
BOM 情報は、ファイルの先頭にある隠し文字の文字列で、一部の編集者がこれが UTF-8 でエンコードされたファイルであることを認識できるようにするために使用されます。ただし、PHP はファイルを読み取るときにこれらの文字を読み出すため、ファイルの先頭に認識できない文字が含まれるという問題が発生します。
例えば、UTF-8形式で保存された画像を生成するPHPファイルの場合、ファイルヘッダーに隠されたBOM情報も配布されるため、生成された画像データは不正となりブラウザで認識できなくなります。
UTF-8 ファイルに BOM 情報が含まれているかどうかを検出するには、ファイルの先頭の 3 文字が 0xEF、0xBB、0xBF であるかどうかを確認します。次の小さなプログラムでは、ユーザーは特定のディレクトリ内のすべてのファイルを走査し、BOM が追加されているかどうかを検出します。
$basedir="."; //この動作のために検出する必要があるディレクトリを変更します
$auto=1; // 検出された BOM 情報を自動的に削除するかどうか。 1 ははい、0 はいいえを意味します。
//以下を変更する必要はありません
if ($dh = opendir($basedir)) {
while (($file = readdir($dh)) !== false) {
if ($file!='.' && $file!='..' && !is_dir($basedir."/".$file)) echo "ファイル名: $file ".checkBOM("$basedir/$file" )."
";
}
クローズ済み($dh);
}
関数 checkBOM ($filename) {
グローバル $auto;
$contents=file_get_contents($filename);
$charset[1]=substr($contents, 0, 1);
$charset[2]=substr($contents, 1, 1);
$charset[3]=substr($contents, 2, 1);
if (ord($charset[1])==239 && ord($charset[2])==187 && ord($charset[3])==191) {
if ($auto==1) {
$rest=substr($contents, 3);
書き換え ($filename, $rest);
return ("BOM が見つかりました。自動的に削除されました。");
} その他 {
return ("BOM が見つかりました。");
}
}
それ以外の場合は return (「BOM が見つかりません。」);
}
関数書き換え ($filename, $data) {
$filenum=fopen($filename,"w");
群れ($filenum,LOCK_EX);
fwrite($filenum,$data);
fclose($filenum);
上記のコードをdel_bom.phpとして保存し、検出するディレクトリを変更して実行します。これは、すべてのページの先頭に空白スペースを生じさせる BOM 情報がどのファイルに含まれているかを検出するのに役立ちます。
コードをコピーします
この記事で説明した内容が皆様の PHP プログラミング設計に役立つことを願っています。