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

PHPは、特にWeb開発の分野で、最新のプログラミングで強力で広く使用されているツールのままです。 1)PHPは使いやすく、データベースとシームレスに統合されており、多くの開発者にとって最初の選択肢です。 2)動的コンテンツ生成とオブジェクト指向プログラミングをサポートし、Webサイトを迅速に作成および保守するのに適しています。 3)PHPのパフォーマンスは、データベースクエリをキャッシュおよび最適化することで改善でき、その広範なコミュニティと豊富なエコシステムにより、今日のテクノロジースタックでは依然として重要になります。

PHPでは、弱い参照クラスを通じて弱い参照が実装され、ガベージコレクターがオブジェクトの回収を妨げません。弱い参照は、キャッシュシステムやイベントリスナーなどのシナリオに適しています。オブジェクトの生存を保証することはできず、ごみ収集が遅れる可能性があることに注意する必要があります。

\ _ \ _ Invokeメソッドを使用すると、オブジェクトを関数のように呼び出すことができます。 1。オブジェクトを呼び出すことができるように\ _ \ _呼び出しメソッドを定義します。 2。$ obj(...)構文を使用すると、PHPは\ _ \ _ Invokeメソッドを実行します。 3。ロギングや計算機、コードの柔軟性の向上、読みやすさなどのシナリオに適しています。

繊維はPhp8.1で導入され、同時処理機能が改善されました。 1)繊維は、コルーチンと同様の軽量の並行性モデルです。 2)開発者がタスクの実行フローを手動で制御できるようにし、I/O集約型タスクの処理に適しています。 3)繊維を使用すると、より効率的で応答性の高いコードを書き込むことができます。

PHPコミュニティは、開発者の成長を支援するための豊富なリソースとサポートを提供します。 1)リソースには、公式のドキュメント、チュートリアル、ブログ、LaravelやSymfonyなどのオープンソースプロジェクトが含まれます。 2)StackOverFlow、Reddit、およびSlackチャネルを通じてサポートを取得できます。 3)開発動向は、RFCに従うことで学ぶことができます。 4)コミュニティへの統合は、積極的な参加、コード共有への貢献、および学習共有への貢献を通じて達成できます。

PHP and Python each have their own advantages, and the choice should be based on project requirements. 1.PHPは、シンプルな構文と高い実行効率を備えたWeb開発に適しています。 2。Pythonは、簡潔な構文とリッチライブラリを備えたデータサイエンスと機械学習に適しています。

PHPは死にかけていませんが、常に適応して進化しています。 1)PHPは、1994年以来、新しいテクノロジーの傾向に適応するために複数のバージョンの反復を受けています。 2)現在、電子商取引、コンテンツ管理システム、その他の分野で広く使用されています。 3)PHP8は、パフォーマンスと近代化を改善するために、JITコンパイラおよびその他の機能を導入します。 4)Opcacheを使用してPSR-12標準に従って、パフォーマンスとコードの品質を最適化します。

PHPの将来は、新しいテクノロジーの傾向に適応し、革新的な機能を導入することで達成されます。1)クラウドコンピューティング、コンテナ化、マイクロサービスアーキテクチャに適応し、DockerとKubernetesをサポートします。 2)パフォーマンスとデータ処理の効率を改善するために、JITコンパイラと列挙タイプを導入します。 3)パフォーマンスを継続的に最適化し、ベストプラクティスを促進します。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

MantisBT
Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

ZendStudio 13.5.1 Mac
強力な PHP 統合開発環境

EditPlus 中国語クラック版
サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

SecLists
SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。
