- 追加された行はこの色です。
- 削除された行はこの色です。
*エラー時に空白ページが出力される場合がある [#vde13d46]
-ページ: BugTrack
-投稿者: [[三浦克介]]
-優先順位: 低
-優先順位: 重要
-状態: 提案
-カテゴリー: 本体バグ
-投稿日: 2004-05-14 (金) 12:59:36
-バージョン:
**メッセージ [#nbc29ec9]
[[pukiwiki:続・質問箱/122]] にもあるように、何らかのエラーが生じた際に、
真っ白な画面になる場合があります。私も、最近、そのようなケースに遭遇し
ましたので、原因の調査を行いました。原因は二つありました。
1. ファイルの存在を file_exists() 関数でチェックしている
***1. ファイルの存在を file_exists() 関数でチェックしている [#j92a3937]
プログラム中の多くの箇所で、ファイルを読込む際に file_exists() 関数で
ファイルの存在をチェックした上で、読み込んでいます。ファイルが存在する
けれども、読込み不許可の場合(UNIX系OSで、パーミッションが600等の場合)、
file_exists() は TRUE を返しますが、読込みはできず、エラーになんります。
file_exists() は TRUE を返しますが、読込みはできず、エラーになります。
is_readable() 関数を使うと、ファイルが存在し、かつ読み込み可能な場合に
のみ TRUE を返しますので、is_readable() でチェックした方が良いのではな
いでしょうか。
2. error_reporting() で E_WARNING を除外している
***2. error_reporting() で E_WARNING を除外している [#e98d4b46]
require() や require_onece() で指定したファイルを読込めなかった場合、
Fatal Errorで実行が中止されますが、この際のエラーメッセージは
E_WARNING として出力されるようです。init.php の冒頭部で、
error_reporting(E_ERROR | E_PARSE);
として、E_WARNING のエラーメッセージ出力を抑止していますので、
require(), require_onece() の読み込み失敗のエラーは出力されません。
E_WARNING を抑止している理由をご存知の方、お教え下さい。
----
#comment