知っていることは知っていること、知らないことは知っていること PHP 初心者を混乱させる 10 の知識ポイント。
[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. 現在のファイルの前に空白行がある。 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);
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;
}
【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. 次のように、フォームに複数のファイル入力ボックスを設定し、配列で名前を付けます。 = "usefile[]" type="file" >
< input name="usefile[]" type="file" >
< input name="usefile[]" type="file" >
< ; /form >
このようにして、サーバー側で以下のテストを行います
echo " < pre > ";
print_r($_FILES);
echo " < /pre > ";
2.フォーム ファイル入力ボックスに複数の設定を設定しますが、次のように名前が異なります。 < input name="usefile_b " type="file" >
< input name="usefile_c" type="file" >
< /form >
サーバー側でも同じテストを実行します。 " < pre > ";
print_r($_FILES);
echo " < /pre > ";
以上、PHP初心者が知っている、知らない、知らない、知っていると迷う10の知識ポイントを紹介しましたので、PHPチュートリアルに興味のある友人の参考になれば幸いです。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











PHPには4つの主要なエラータイプがあります。1。notice:わずかなものは、未定義の変数へのアクセスなど、プログラムを中断しません。 2。警告:通知よりも深刻で、ファイルを含むなど、プログラムを終了しません。 3。ファタラー:最も深刻なのは、機能を呼び出すなど、プログラムを終了します。 4。ParseError:構文エラーは、エンドタグの追加を忘れるなど、プログラムの実行を防ぎます。

PHPとPythonにはそれぞれ独自の利点があり、プロジェクトの要件に従って選択します。 1.PHPは、特にWebサイトの迅速な開発とメンテナンスに適しています。 2。Pythonは、データサイエンス、機械学習、人工知能に適しており、簡潔な構文を備えており、初心者に適しています。

PHPでは、Password_hashとpassword_verify関数を使用して安全なパスワードハッシュを実装する必要があり、MD5またはSHA1を使用しないでください。 1)password_hashセキュリティを強化するために、塩値を含むハッシュを生成します。 2)password_verifyハッシュ値を比較して、パスワードを確認し、セキュリティを確保します。 3)MD5とSHA1は脆弱であり、塩の値が不足しており、最新のパスワードセキュリティには適していません。

PHPは、電子商取引、コンテンツ管理システム、API開発で広く使用されています。 1)eコマース:ショッピングカート機能と支払い処理に使用。 2)コンテンツ管理システム:動的コンテンツの生成とユーザー管理に使用されます。 3)API開発:RESTFUL API開発とAPIセキュリティに使用されます。パフォーマンスの最適化とベストプラクティスを通じて、PHPアプリケーションの効率と保守性が向上します。

HTTPリクエストメソッドには、それぞれリソースを取得、送信、更新、削除するために使用されるGET、POST、PUT、および削除が含まれます。 1. GETメソッドは、リソースを取得するために使用され、読み取り操作に適しています。 2. POSTメソッドはデータの送信に使用され、新しいリソースを作成するためによく使用されます。 3. PUTメソッドは、リソースの更新に使用され、完全な更新に適しています。 4.削除メソッドは、リソースの削除に使用され、削除操作に適しています。

PHPは、サーバー側で広く使用されているスクリプト言語で、特にWeb開発に適しています。 1.PHPは、HTMLを埋め込み、HTTP要求と応答を処理し、さまざまなデータベースをサポートできます。 2.PHPは、ダイナミックWebコンテンツ、プロセスフォームデータ、アクセスデータベースなどを生成するために使用され、強力なコミュニティサポートとオープンソースリソースを備えています。 3。PHPは解釈された言語であり、実行プロセスには語彙分析、文法分析、編集、実行が含まれます。 4.PHPは、ユーザー登録システムなどの高度なアプリケーションについてMySQLと組み合わせることができます。 5。PHPをデバッグするときは、error_reporting()やvar_dump()などの関数を使用できます。 6. PHPコードを最適化して、キャッシュメカニズムを使用し、データベースクエリを最適化し、組み込み関数を使用します。 7

Phpoopでは、self ::は現在のクラスを指し、親::は親クラスを指し、静的::は後期静的結合に使用されます。 1.Self ::静的方法と一定の呼び出しに使用されますが、後期静的結合をサポートしていません。 2.Parent ::サブクラスには、親クラスのメソッドを呼び出すために使用され、プライベートメソッドにアクセスできません。 3.Static ::継承と多型に適した後期静的結合をサポートしますが、コードの読みやすさに影響を与える可能性があります。

PHPは、$ \ _ファイル変数を介してファイルのアップロードを処理します。セキュリティを確保するための方法には次のものが含まれます。1。アップロードエラー、2。ファイルの種類とサイズを確認する、3。ファイル上書きを防ぐ、4。ファイルを永続的なストレージの場所に移動します。
