【1】最新の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 ']
Client マシン ファイルの元の名前 (パスを含む)。
$_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'] などと同等です。 。
【2】win32 でのセッションが正常に動作しない
php.ini のデフォルト session.save_path = /tmp
これは明らかに Linux での設定であり、PHP は win32 でセッションファイルを読み書きできず、セッションを使用できません。これを「絶対パスで十分です」に変更します (例: session.save_path = c:windowstemp)。
【3】エラーメッセージの表示
php.iniのdisplay_errors = On、error_reporting = E_ALLの場合、エラー修正のためにデバッグ中にすべてのエラーとプロンプトが表示されます。メソッドの場合、ほとんどのエラー メッセージは未定義の変数に関するものです。変数が割り当てられる前に呼び出されると、プロンプトが表示されます。解決策は、$foo が表示されている場合は、if(isset($foo)) echo $foo または echo @$foo を実行することです。
【4】ヘッダーはすでに送信されています
このエラーは通常、HEADER を使用するときに表示されます。次のような理由が考えられます。 1. HEADER を使用する前に PRING または ECHO を実行する 2. ヘッダーの前に空白行がある。 3. ファイルを INCLUDE した場合、ファイルの末尾に空白行がある場合、このエラーは行または出力でも発生します。
【5】php.iniを変更しても変化なし
IISやApacheなどのWebサーバーを再起動すると、最新の設定が適用されます。
【6】SQL文が機能せず、データベース操作が失敗する場合があります。デバッグする最も簡単な方法は、SQL ステートメントをエコーして変数の値を取得できるかどうかを確認することです。
[7] include と require の違い
インクルードするファイルが存在しない場合、include は通知を求め、require は次のステートメントを実行し続けます。致命的なエラーが発生して終了します。テストによると、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);
$file_data を返す;
}
【8】isset()とempty()の違い
どちらも変数のテストに使用されますが、isset()は変数に値が代入されているかどうかをテストするのに対し、empty()は変数に値が代入されているかどうかをテストしますは空です。 PHP で値を割り当てずに変数を参照する場合は許可されますが、注意事項が表示されます。変数に null 値、$foo=""、$foo=0、または $foo=false が割り当てられている場合、empty($foo) は true を返し、isset($foo) も true を返します。つまり、null 値を割り当てると、変数をログアウトしないでください。変数の登録を解除するには、unset($foo) または $foo=NULL を使用します。
【9】mysqlのクエリ文にキーワードが含まれています
PHPがmysqlにクエリを実行する際、mysqlのテーブル名やカラム名にキーワードが含まれる場合があり、この時クエリにエラーが発生します。たとえば、テーブル名が order の場合、クエリ中にエラーが発生します。簡単な方法は、select * from のように、SQL ステートメントのテーブル名または列名に `[タブ キーの上] を追加することです。 「注文」。
【10】HTTP プロトコルを通じて複数のファイルを一度にアップロードする方法
には 2 つのアイデアがあり、同じメソッドを 2 つ実装しています。具体的な手順は自分で設計する必要があります
1. 以下のように、フォームに複数のファイル入力ボックスを設定し、配列で名前を付けます。 = "usefile[]" type="file" >
< input name="usefile[]" type="file" >
< input name="usefile[]" type="file" >
< ; /form > 複数のファイル入力ボックス。次のように名前が異なります:
< form action="" method="post" >
< input name="usefile_a" type="file" > < input name=" usefile_b" type="file" >
< input name="usefile_c" type="file" >
< /form >
サーバー側でも同じテストを実行します。 " < pre > "
print_r($_FILES);
echo " < /pre > ";