PHPのマジックメソッドの概要と使用例
この記事では主にPHPのマジックメソッドの概要と使用例を紹介します。 これらはすべて特定の状況下でトリガーされます。二重アンダースコアを付けると、必要な友達が参照できるようになります
。マジックメソッドはオブジェクト指向PHPのユニークな機能です。これらは特定の状況でトリガーされ、すべて二重アンダースコアで始まります。パターン メソッドを使用すると、PHP オブジェクト指向でオーバーロードを簡単に実装できます (オーバーロードとは、クラスの属性とメソッドを動的に作成することを意味します)。多くのマジック メソッドはペアで表示されます。以下に、PHP の現在のパターン メソッドをすべてリストします。
1.__構築、__破壊
__constuct はオブジェクトの構築時に呼び出されます;
__destruct は、オブジェクトが明示的に破棄されるか、スクリプトが終了するときに呼び出されます。
2.__get、__set
アクセスできない、または存在しないプロパティに値を割り当てるときに__setが呼び出されます
アクセスできない属性、または存在しない属性を読み取るときに__getが呼び出されます
3.__isset、__unset
アクセスできない、または存在しないプロパティに対して isset() または empty() が呼び出された場合、__isset が呼び出されます
__unsetは、アクセスできないプロパティまたは存在しないプロパティの設定を解除するときに呼び出されます
4.__call、__callStatic
アクセスできない、または存在しないメソッドを呼び出すときに__callが呼び出されます
__callStaticは、アクセスできない、または存在しない静的メソッドを呼び出すときに呼び出されます
5._寝て__起きる
__sleep は、serialize を使用するときに呼び出されます。大きなオブジェクトのすべてのデータを保存する必要がない場合に便利です
__wakeup は unserialize が使用されるときに呼び出され、オブジェクトの初期化に使用できます
6.__クローン
オブジェクトのクローン作成時に呼び出され、オブジェクトのクローン作成動作を調整するために使用されます
7.__toString
クラスが文字列に変換されるときに呼び出されます
8.__invoke
オブジェクトが関数として呼び出されるときに呼び出されます
9.__set_state
この静的メソッドは、クラスをエクスポートするために var_export() が呼び出されるときに呼び出されます。 __set_state の戻り値を var_export の戻り値として使用します。
10.__デバッグ情報
オブジェクトを出力するためにvar_dump()が呼び出されたときに呼び出されます(すべての属性を出力したくない場合)PHP5.6バージョンに適用されます
PHPマジックメソッドの使用例は以下の通りです:
?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 |
クラスマジック { パブリック $var = 'テスト';
//オブジェクトの作成時に呼び出されるコンストラクター パブリック関数 __construct() { echo '__construct が呼び出されました'.PHP_EOL; }
//オブジェクトへの参照が削除され、オブジェクトが破棄され、exit() が呼び出された後、およびスクリプトが閉じられたときに呼び出されます パブリック関数 __destruct() { echo '__destruct が呼び出されました'.PHP_EOL; }
//アクセスできないプロパティまたは存在しないプロパティに値を割り当てるときに呼び出されます パブリック関数 __set($name, $value) { echo $name.'-'.$value; echo '__set が呼び出されました'.PHP_EOL; }
//アクセスできないプロパティまたは存在しないプロパティを読み取るときに呼び出されます パブリック関数 __get($name) { $nameをエコー; echo '__get Called'.PHP_EOL; }
//アクセスできない、または存在しないメソッドを呼び出すときに呼び出されます パブリック関数 __call($name, $arguments) { echo $name . '-' .implode(',', $arguments); echo '__call が呼び出されました'.PHP_EOL; }
//アクセスできない、または存在しない静的メソッドを呼び出すときに呼び出されます パブリック静的関数 __callStatic($name, $arguments) { echo $name . '-' .implode(',', $arguments); echo '__callStatic が呼び出されました'.PHP_EOL; }
//アクセスできないプロパティまたは存在しないプロパティに対して isset() または empty() が呼び出されたときに呼び出されます パブリック関数 __isset($name) { $nameをエコー; echo '__isset が呼び出されます'.PHP_EOL; true を返す; }
//アクセスできないプロパティまたは存在しないプロパティの設定を解除するときに呼び出されます パブリック関数 __unset($name) { $nameをエコー; echo '__unset が呼び出されました'.PHP_EOL; }
//シリアル化時に呼び出され、大きなオブジェクトのすべてのデータを保存する必要がない場合に便利です パブリック関数 __sleep() { echo '__sleep が呼び出されました'.PHP_EOL; 配列を返す('var1111111111'); }
//アンシリアル化時に呼び出され、一部のオブジェクトの初期化に使用できます パブリック関数 __wakeup() { echo '__wakeup が呼び出されています'.PHP_EOL; $this->var = 'ウェイクアップ後にテスト'; }
//クラスが文字列に変換されるときに呼び出されます パブリック関数 __toString() { return '__toString が呼び出されました'.PHP_EOL; }
//オブジェクトのクローン作成時に呼び出され、オブジェクトのクローン作成動作を調整するために使用されます パブリック関数 __clone() { echo '__clone が呼び出されました'.PHP_EOL; }
//オブジェクトが関数として呼び出されるときに呼び出されます パブリック関数 __invoke() { echo '__invoke が呼び出されます'.PHP_EOL; }
//この静的メソッドは、クラスをエクスポートするために var_export() が呼び出されるときに呼び出されます。 __set_state の戻り値を var_export の戻り値として使用します。 パブリック静的関数 __set_state($arr) { return '__set_state が呼び出されました'.PHP_EOL; }
//オブジェクトを出力するために var_dump() が呼び出されるときに呼び出されます (すべての属性を出力したくない場合) PHP5.6 バージョンに適用されます パブリック関数 __debuginfo($arr) { echo '__debuginfo が呼び出されました'.PHP_EOL; 配列を返す( 'var' => '__debuginfo からテスト' ); } }
$m = new Magic() //__construct() が呼び出されます $m->not_exist_property = //__set() が呼び出されます echo $m->not_exist_property;//__get() が呼び出されます $m->abc(1,2,3) //__call() が呼び出されます ;echo isset($m->not_exist_property); //__isset() が呼び出され、bool 値が返されます unset($m->not_exist_property) //__unset() が呼び出されます echo $tmp = Serialize($m) //__sleep() が呼び出されます unserialize($tmp); //__wakeup() が呼び出されます $m1 = clone $m; //__clone() が呼び出され、オブジェクトはデフォルトで参照によって渡され、オブジェクトは clone キーワードを使用してコピーできます $m() //__invoke() eval( '$m2 = ' . var_export ( $m , true ) . ';' );var_dump($m2); var_dump($m); //最後に __destruct() が呼び出されます
/* 結果: __コンストラクトと呼ばれる not_exist_property-test__set が呼び出されました not_exist_property__が呼び出される abc-1,2,3__電話がかかりました not_exist_property__ が呼び出されるセットです 1not_exist_property__unset が呼び出されました __スリープコール O:5:"Magic":1:{s:13:"var1111111111";N;}__ウェイクアップが呼び出されました __destruct が呼び出されました __クローンが呼ばれました __呼び出して呼ばれる string(20) "__set_state が呼び出されました 「 」クラスマジック#1 (1) { パブリック $var => string(4) "テスト" } __destruct が呼び出されました __destruct が呼び出されました
*/ |

セッション関連のXSS攻撃からアプリケーションを保護するには、次の測定が必要です。1。セッションCookieを保護するためにHTTPonlyとセキュアフラグを設定します。 2。すべてのユーザー入力のエクスポートコード。 3.コンテンツセキュリティポリシー(CSP)を実装して、スクリプトソースを制限します。これらのポリシーを通じて、セッション関連のXSS攻撃を効果的に保護し、ユーザーデータを確保できます。

PHPセッションのパフォーマンスを最適化する方法は次のとおりです。1。遅延セッション開始、2。データベースを使用してセッションを保存します。これらの戦略は、高い並行性環境でのアプリケーションの効率を大幅に改善できます。

thesession.gc_maxlifettinginttinginphpdethinesthelifsessessiondata、setinseconds.1)it'sconfiguredinphp.iniorviaini_set()。 2)AbalanceSneededToAvoidPerformanceIssues andunexpectedLogouts.3)php'sgarbagecollectionisisprobabilistic、影響を受けたBygc_probabi

PHPでは、session_name()関数を使用してセッション名を構成できます。特定の手順は次のとおりです。1。session_name()関数を使用して、session_name( "my_session")などのセッション名を設定します。 2。セッション名を設定した後、session_start()を呼び出してセッションを開始します。セッション名の構成は、複数のアプリケーション間のセッションデータの競合を回避し、セキュリティを強化することができますが、セッション名の一意性、セキュリティ、長さ、設定タイミングに注意してください。

セッションIDは、機密操作の前、30分ごとにログイン時に定期的に再生する必要があります。 1.セッション固定攻撃を防ぐためにログインするときにセッションIDを再生します。 2。安全性を向上させるために、敏感な操作の前に再生します。 3.定期的な再生は長期的な利用リスクを減らしますが、ユーザーエクスペリエンスの重量を量る必要があります。

PHPのセッションCookieパラメーターの設定は、session_set_cookie_params()関数を通じて達成できます。 1)この関数を使用して、有効期限、パス、ドメイン名、セキュリティフラグなどのパラメーターを設定します。 2)session_start()を呼び出して、パラメーターを有効にします。 3)ユーザーログインステータスなど、ニーズに応じてパラメーターを動的に調整します。 4)セキュリティを改善するために、セキュアとhttponlyフラグを設定することに注意してください。

PHPでセッションを使用する主な目的は、異なるページ間でユーザーのステータスを維持することです。 1)セッションはsession_start()関数を介して開始され、一意のセッションIDを作成し、ユーザーCookieに保存します。 2)セッションデータはサーバーに保存され、ログインステータスやショッピングカートのコンテンツなど、さまざまなリクエスト間でデータを渡すことができます。

サブドメイン間でセッションを共有する方法は?一般的なドメイン名にセッションCookieを設定することにより実装されます。 1.セッションCookieのドメインをサーバー側の.example.comに設定します。 2。メモリ、データベース、分散キャッシュなど、適切なセッションストレージ方法を選択します。 3. Cookieを介してセッションIDを渡すと、サーバーはIDに基づいてセッションデータを取得および更新します。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

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

DVWA
Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

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

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

mPDF
mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。
