ホームページ >バックエンド開発 >PHPチュートリアル >PHP バッチは utf-8 ファイルの BOM ヘッダーをクリアします
PHP バッチは utf-8 ファイルの BOM ヘッダーをクリアします
<?php if (isset($_GET['dir'])){ //设置文件目录 $basedir=$_GET['dir']; }else{ $basedir = '.'; } $auto = 1; checkdir($basedir); function checkdir($basedir){ if ($dh = opendir($basedir)) { while (($file = readdir($dh)) !== false) { if ($file != '.' && $file != '..'){ if (!is_dir($basedir."/".$file)) { echo "filename: $basedir/$file ".checkBOM("$basedir/$file")." <br>"; }else{ $dirname = $basedir."/".$file; checkdir($dirname); } } } closedir($dh); } } function checkBOM ($filename) { global $auto; $contents = file_get_contents($filename); $charset[1] = substr($contents, , 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); rewrite ($filename, $rest); return ("<font color=red>BOM found, automatically removed._<a href=http://www.k686.com>http://www.k686.com</a></font>"); } else { return ("<font color=red>BOM found.</font>"); } } else return ("BOM Not Found."); } function rewrite ($filename, $data) { $filenum = fopen($filename, "w"); flock($filenum, LOCK_EX); fwrite($filenum, $data); fclose($filenum); } ?>
それを php ファイルとして保存し、Web サイトのルート ディレクトリに置きます。このファイルは、私が個人的にテストしたもので、完全に安全です。
Web サイトのルート ディレクトリに配置して実行すると、すべてのファイルがスキャンされます。
例: http://www.baidu.com/checkbom.php
を実行するディレクトリを指定することもできます
例: http://www.baidu.com/checkbom.php?dir=html