今日 CI フレームワークを学習中に問題が発生しました:
PHP エラーが発生しました
重大度: 通知
メッセージ: 未定義の変数: ユーザー
一般に、デフォルトの通常の PHP ファイルに未定義の宣言された変数を出力することはできません。エラーが報告されますが、codeigniter フレームワークではエラーが報告されます。これは、初心者であるため、このエラー メッセージをコード内でブロックしたいと考えている「怠け者」にとっては非常に不便です。 . . @ も使用されていましたが、@ を使用するとパフォーマンスが大幅に低下するという意見が多かったです...
最後に、codeigniter が意図的にこのエラー メッセージを表示するのではないかと考えました。 codeigniter が Notice 情報を表示しないようにするにはどうすればよいですか?」と考えたとき、ふと思いつきました。index.php エントリ内の error_reporting(E_ALL); が問題を引き起こしていることがわかりました。これを
error_reporting(E_ALL ^ E_NOTICE) に変更するだけです。 );
他のエラーに影響を与えずにこのエラーを取り除きます。
見つかった情報は次のとおりです。
error_reporting() PHP のエラー レベルを設定し、現在のレベルを返します。
構文
error_reporting(report_level)
パラメータレベルが指定されていない場合は、現在のエラーレポートレベルが返されます。レベルに指定できる値は次のとおりです:
1 E_ERROR
2 E_WARNING
4 E_PARSE
8 E_NOTICE
16 E_CORE_ERROR
32 E_CORE_WARNING
64 E_COMPILE_ERROR
128 E_COMPILE_WARNING
25 6 E_USER_ERROR
512 E_USER_WARNING
1024 E_USER_NOTICE
2047 E_ALL
2048 E_STRICT
E_NOTICE は、通常の状況が記録されないことを意味し、存在しない変数にアクセスしようとしたり、存在しないファイルを表示するために stat() 関数を呼び出したりするなど、プログラムにエラー状況が発生した場合にのみ使用されます。
E_WARNING は通常表示されますが、プログラムの実行は中断されません。これはデバッグに役立ちます。たとえば、問題のある正規表記を使用して ereg() を呼び出します。通常は
E_ERROR が表示され、プログラムの実行が中断されます。これは、このマスクを使用してメモリ構成やその他のエラーを追跡できないことを意味します。
E_PARSE 構文からのエラーを解析します。
E_CORE_ERROR E_ERROR と似ていますが、PHP コアによって引き起こされるエラーは除外されます。
E_CORE_WARNING E_WARNING と似ていますが、PHP コア エラー警告は含まれません。
PHP Error Reporting
php.ini ファイルには多くの構成設定があります。 Linux への PHP および Apache 2 のインストールに関するドキュメントに示されているように、php.ini ファイルがすでにセットアップされ、適切なディレクトリに配置されている必要があります。 PHP アプリケーションをデバッグするときに注意すべき構成変数が 2 つあります。 2 つの変数とそのデフォルト値は次のとおりです:
display_errors = Off
error_reporting = E_ALL
これら 2 つの変数の現在のデフォルト値は、php.ini ファイル内で検索することで見つけることができます。 display_errors 変数の目的は明らかです。この変数は、エラーを表示するかどうかを PHP に指示します。デフォルト値はオフです。ただし、開発プロセスを容易にするために、この値を On に設定します。
display_errors = On
error_reporting 変数のデフォルト値は E_ALL です。この設定では、不適切なコーディング方法から無害なヒント、エラーに至るまで、あらゆるものが表示されます。 E_ALL は、ブラウザの出力を混乱させる小さな事柄 (変数が初期化されていないなど) についてのヒントも画面上に表示するため、開発目的には少し粒度が高すぎます。私が知りたいのはエラーと不適切なコーディング方法だけであり、無害なヒントは知りたいわけではありません。したがって、error_reporting のデフォルト値を次の値に置き換えてください:
error_reporting = E_ALL & ~E_NOTICE
Apache を再起動すれば準備は完了です。次に、Apache で同じことを行う方法を学びます。
サーバー上のエラー報告
Apache の動作によっては、コンピュータ上に複数のバージョンの PHP が存在する可能性があるため、PHP でエラー報告を有効にしても機能しない場合があります。 Apache は 1 つの php.ini ファイルしか参照できないため、Apache が使用している PHP バージョンを判断することが難しい場合があります。 Apache が自身の設定にどの php.ini ファイルを使用しているかわからないことは、セキュリティ上の問題です。ただし、正しいエラー レベルが設定されるように Apache で PHP 変数を構成する方法があります。
また、サーバー側でこれらの構成変数を設定して、php.ini ファイルをオーバーライドまたはプリエンプトして、より高いレベルのセキュリティを提供する方法を知っておくと良いでしょう。
Apache を設定するときは、/conf/httpd.conf の http.conf ファイルの基本設定をすでに行っている必要があります。
php.ini ファイルで既に行ったことを行うには、次の行を httpd.conf に追加し、php.ini ファイルを上書きします:
php_flag display_errors on
php_value error_reporting 2039
これにより、php.ini ファイルが上書きされます。それは、display_errors が設定されているフラグと、error_reporting の値です。値 2039 は E_ALL および ~E_NOTICE を表します。 E_ALL を使用する場合は、値を 2047 に設定します。繰り返しますが、Apache を再起動する必要があります。
次に、サーバーでのエラー報告をテストする必要があります。
error_reporting() 関数に関しては、一部のエラー メッセージをシールドできますが、PHP コアによって発生したエラーはシールドできません。PHP コアによって発生したエラーは、PHP ファイルのコンパイルの失敗を直接引き起こすためです。 PHP に従う エンコーディング ルールの記述によって発生するエラーはブロックできません