ホームページ >バックエンド開発 >PHPチュートリアル >PHP初心者を混乱させる10の知識ポイント
最新の PHP バージョンでは、自動グローバル変数がオフになっているため、前のページから送信された変数を取得するには、$_GET['foo']、$_POST['foo']、$_SESSION['foo '] を使用します。 ] 取得するため。もちろん、自動グローバル変数を on に変更することもできます (php.ini を register_globals = On に変更します)。互換性を考慮して、新しい記述方法に慣れることをお勧めします。
注: PHP のスーパーグローバル変数
PHP 4.2.0 以降、 register_globals のデフォルト値はオフになっており、その結果、$PHP_SELF や設定した SESSION 変数など、これまで直接使用できた多くの変数に "$ 形式でアクセスできなくなりました。変数名」。これにより多くの変更が残る可能性がありますが、セキュリティの向上に役立ちます。これらの変数にアクセスするには、次のように PHP スーパーグローバル変数を使用する必要があります:
$_SERVER
変数は Web サーバーによって設定されるか、現在のスクリプトの実行環境に直接関連付けられます。古い $HTTP_SERVER_VARS 配列に似ています。前の $PHP_SELF は $_SERVER['PHP_SELF'] に対応します。phpinfo を使用して $_SERVER 変数を表示できます。
$_GET
HTTP GET メソッド経由でスクリプトに送信される変数。古い $HTTP_GET_VARS 配列に似ています。
$_POST
HTTP POST メソッド経由でスクリプトに送信される変数。古い $HTTP_POST_VARS 配列に似ています。
$_COOKIE
HTTP Cookie メソッドを介してスクリプトに送信される変数。古い $HTTP_COOKIE_VARS 配列に似ています。
$_SESSION
スクリプト セッションに現在登録されている変数。古い $HTTP_SESSION_VARS 配列に似ています。
$_FILES
HTTP POST ファイルのアップロードを通じてスクリプトに送信される変数。古い $HTTP_POST_FILES 配列に似ています。
$_ENV
実行環境によってスクリプトに送信される変数。古い $HTTP_ENV_VARS 配列に似ています。
$_FILES 変数の場合: (ファイル ドメイン フィールドは「myfile」)
$_FILES['myfile']['name']
クライアント マシン ファイルの元の名前 (パスを含む)。
$_FILES['myfile']['type']
ファイルの MIME タイプ。「image/gif」など、この情報に対するブラウザのサポートが必要です。
$_FILES['myfile']['size']
アップロードされたファイルのサイズ (バイト単位)。
$_FILES['myfile']['tmp_name']
ファイルのアップロード後にサーバーに保存される一時ファイル名 (パスを含む)。
$_FILES['myfile']['error']
ファイルのアップロードに関連するエラー コード。 ['error'] は PHP 4.2.0 で追加されました。
php.ini の register_globals が on に設定されている場合、$myfile_name は $_FILES['myfile']['name'] に相当し、$myfile_type は $_FILES['myfile']['type' ]wait に相当します。 。
php.ini のデフォルトの session.save_path = /tmp
これは明らかに Linux での設定です。win32 では PHP がセッション ファイルを読み書きできないため、セッションを session.save_path = c:windowstemp などの絶対パスに変更するだけです。
php.ini で display_errors = On および error_reporting = E_ALL を指定すると、すべてのエラーとプロンプトが表示されます。以前の PHP 記述方法を使用すると、エラー メッセージのほとんどが表示されます。未定義変数について。変数が割り当てられる前に呼び出されると、プロンプトが表示されます。解決策は、$foo が表示されている場合は、if(isset($foo)) echo $foo または echo @$foo を実行することです。
このエラーは通常、HEADER を使用するときに発生します。次のような理由が考えられます。 1. HEADER を使用する前に PRING または ECHO を実行した。 2. 現在のファイルの前に空白行がある。 3. ファイルを INCLUDE した可能性がある。ファイル このエラーは、出力または末尾に空白行がある場合にも発生します。
IIS、ApacheなどのWebサーバーを再起動すると、最新の設定が適用されます。
データベース操作が失敗しました。デバッグする最も簡単な方法は、SQL ステートメントをエコーして変数の値を取得できるかどうかを確認することです。
この 2 つに大きな違いはありません。インクルードするファイルが存在しない場合、インクルードはプロンプトを表示し、次のステートメントの実行を続行すると致命的なエラーが表示されて終了します。テストによると、win32 プラットフォームでは、ファイルは最初にインクルードされてから実行されるため、ディレクトリの混乱を引き起こす可能性があるため、インクルードされるファイルに include ステートメントや require ステートメントを含めないことが最善です。 *nux では状況が異なる可能性がありますが、まだテストしていません。ファイルを複数回インクルードしたくない場合は、include_once または require_once## を使用してドキュメント データの読み取りと書き込みを行うことができます:
function r($file_name) { $filenum=@fopen($file_name,"r"); @flock($filenum,LOCK_SH); $file_data=@fread($filenum,filesize($file_name)); @fclose($filenum); return $file_data; } function w($file_name,$data,$method="w"){ $filenum=@fopen($file_name,$method); flock($filenum,LOCK_EX); $file_data=fwrite($filenum,$data); fclose($filenum); return $file_data; }
どちらも変数をテストするために使用されますが、isset() は変数に値が割り当てられているかどうかをテストし、empty() は値が割り当てられている変数が空かどうかをテストします。 PHP で値を割り当てずに変数を参照する場合は許可されますが、注意事項が表示されます。変数に null 値、$foo=""、$foo=0、または $foo=false が割り当てられている場合、empty($foo) は true を返し、isset($foo) も true を返します。つまり、null 値を割り当てると、変数をログアウトしないでください。変数の登録を解除するには、unset($foo) または $foo=NULL を使用します。
PHP が MySQL にクエリを実行する場合、MySQL のテーブル名またはカラム名にキーワードが含まれる場合があり、このときクエリでエラーが発生します。たとえば、テーブル名が order の場合、クエリ中にエラーが発生します。簡単な方法は、SQL ステートメントのテーブル名または列名に `[タブ キーの上] を追加して区別することです。たとえば、select * とします。 「注文」から。
同じメソッドの 2 つのアイデアと 2 つの実装があります。具体的な手順は自分で設計する必要があります
1. 次のように、フォームに複数のファイル入力ボックスを設定し、配列で名前を付けます:
< form action="" method="post" > < input name="usefile[]" type="file" > < input name="usefile[]" type="file" > < input name="usefile[]" type="file" > < /form >
このようにして、サーバー側で次のテストを実行します
echo " < pre > "; print_r($_FILES); echo " < /pre > ";
2. フォームに複数のファイル入力ボックスを設定しますが、次のように名前が異なります。
< form action="" method="post" > < input name="usefile_a" type="file" > < input name="usefile_b" type="file" > < input name="usefile_c" type="file" > < /form >
サーバー側でも同じテストを実行します:
echo " < pre > "; print_r($_FILES); echo " < /pre > ";