ホームページ  >  記事  >  バックエンド開発  >  PHP初心者を混乱させる10の知識ポイント

PHP初心者を混乱させる10の知識ポイント

巴扎黑
巴扎黑オリジナル
2016-11-08 10:41:151162ブラウズ

[1] 変数の get、post、および session はページ間で転送できません。最新の PHP バージョンでは、自動グローバル変数がオフになっているため、前のページから送信された変数を取得するには、
$_GET['foo'] を使用します。 , $_POST['foo'],$_SESSION['foo'] を取得します。もちろん、自動グローバル変数を on に変更することもできます (php.ini を register_globals = On に変更します)。互換性を考慮すると、新しい記述方法 www.lampbrother.net に慣れることをお勧めします。
注: 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'] などと同等です。 。

【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の場合、エラー修正のためにデバッグ中にすべてのエラーとプロンプトが表示されます。メソッドの場合、ほとんどのエラー メッセージは未定義の変数に関するものです。解決策は、変数に値が割り当てられる前にそれを検出またはブロックすることです。 if(isset($foo)) echo $foo または echo を実行します。 @$foo

[4] ヘッダーはすでに送信されました
このエラーは通常、HEADER を使用するときに表示されます。次のような理由が考えられます。 1. HEADER を使用する前に PRING または ECHO を実行した。 2. HEADER に空白行がある。 3. ファイルを INCLUDE した場合、ファイルの末尾に空白行がある場合、このエラーは行または出力でも発生します。

【5】php.iniを変更しても変化なし
IISやApacheなどのWebサーバーを再起動すると、最新の設定が適用されます。

【6】SQL文が機​​能せず、データベース操作が失敗する場合があります。デバッグする最も簡単な方法は、SQL ステートメントをエコーし​​て変数の値を取得できるかどうかを確認することです。

【7】includeとrequireの違い
両者に大きな違いはありません。 includeは、インクルードするファイルが存在しない場合に通知を促し、その後次のステートメントを実行し続けると、致命的なエラーを要求します。エラーが発生して終了します。テストによると、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);
$file_data を返す
}
関数 w($file_name,$data,$method="w"){
$filenum=@fopen($file_name,$method);
$file_data =fwrite($filenum,$data);
fclose($filenum);
return $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 の場合、クエリ中にエラーが発生します。簡単な方法は、SQL ステートメントのテーブル名または列名に `[タブ キーの上] を追加して区別することです。たとえば、select * とします。 「注文」から。

【10】HTTPプロトコルで複数のファイルを一度にアップロードする方法
同じ方法を2つ実装したアイデアが2つあります。特定のプログラムは自分で設計する必要があります
1. 次のように、フォームに複数のファイル入力ボックスを設定し、配列で名前を付けます:






サーバー側 echo "
";
echo " ";




のように、複数のファイル入力ボックスを設定します。

サーバー上で同じテストを実行します:
echo " ";
echo " ";

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。