まとめ
Java のリフレクションと比較すると、PHP のリフレクションはまさに良心の働きです。ただし、メンテナンスの観点からは Java の方が優れており、さらに利点があります。ただし、処理が煩雑であるため、Java のリフレクション メカニズムに一定の学習コストがかかります。
今日はPHPのリフレクション技術を使ってクラス情報を取得してみました。
コアの操作は PHP の公式ヘルプ ドキュメントで参照できます。ここで最も一般的に使用されるのは
getProperties getMethods
ターゲット クラスです
リフレクションの結果とメンテナンスをより適切に示すために、クラスを作成してみましょう。
<?phpclass Person { private $name; private $age; private $address; public function __construct($name, $age, $address) { $this->name = $name; $this->age = $age; $this->address = $address; } public function setter($key, $value) { exec ( "{$this}->" . $key . "={$value}" ); } /** * 通配型的getter方法不好用。 * <br /> * 原因: Object Person can not be converted to string. * * @param unknown $key * @return string */ public function getter($key) { return exec ( "$this" . "->{$key}" ); } /** * 模拟Java语言实现的getter方法。<br /> * * 缺点: 需要为每一个private属性提供单独的getter方法,使得代码略显臃肿。 */ public function getName() { return $this->name; } }class Grade { private $name; public function __construct($name) { $this->name = $name; } public function setName($name) { $this->name = $name; } public function getName() { return $this->name; } }
読み込みの問題
読み込みメカニズム
正式な反映操作の前に、まず __autoload
の自動読み込みメカニズムについて説明します。名前が示すように、(クラスまたはその他の PHP ファイル) が自動的にロードされます。 __autoload
自动加载机制。顾名思义,自动化的进行加载(类,也可以是其他php文件)呗。
对于更深层次而言,这就涉及到PHP解释器的工作原理了。也就是说,我们不可能一个项目只写一个php文件,相反,一个项目中可能会有数以百计的php文件,而且不可避免的会进行相互调用。
也就是说,我们在A文件中声明并实现了一个加法函数,而需要在B文件中进行调用。很明显B文件中根本没有实现这个加法,所以PHP解释器就没办法进行加法运算了。
这个时候就需要让PHP解释器知道这个加法怎么做,于是就需要require / include
包含了这个加法函数的A文件了。
这样,PHP解释器就知道如何解释并运行咱们的PHP文件了。
与PHP相似的是,在Java语言中我们只需要在源文件前面添加import
语句,Java虚拟机就能自动的在相关的类信息了。而且强类型的Java可以在编译之前就发现这样的问题,所以代码维护起来比较方便一点。而PHP则需要进行手动的 include/require
了。
但是应该清楚的是,这两者换汤不换药而已。
自动加载机制
但是如果对每一个要被引用的php文件进行手动的加载的话,可能就要写好多个这样的加载语句了。所以为了方便处理这种问题,PHP5之后引入了自动加载机制。
void __autoload ( string $class )
$class
就是要进行加载的类的名称,请注意是类
的名称。
怎么使用?
既然自动加载机制这么好,那么我们要怎么使用呢?
答案就是在需要加载其他类文件的php中,添加一个自定义的__autoload($class)
函数即可。 还是以刚才的文件AB来举例。
文件A中有一个写好的类Person,在文件B中要进行使用。这个时候在文件B中添加一个__aotoload
函数即可。而且这个函数的写法也比较的简单(一切按照最简思路来设计的话)。
function __autoload($class) { $filename = "$class.class.php"; if(!file_exists($filename)){ throw new RuntimeException("$filename 文件不存在!"); }else { require "$filename"; } }
PHP解释器在扫描到文件B的时候会先进行检查,如果未引入目标类Person,则会判断有没有实现__autoload
,如果存在则使用自动加载函数进行加载,否则报错退出。
注意问题
虽然上面的自动加载函数比较简单,但是现实中却需要为此付出很多的“代价”,也就是被加载的类文件的名称要和类保持一致(无需区分大小写)。如:
要加载的类的名称为Person, 则该类所在的文件的名称需要为person.class.php,或者Person.class.php
而且,路径问题也是一个比较棘手的问题,在这个简易的自动加载函数中也不难看到,这里他们位于同级目录下,试想一下不满足这个条件的情形,就可以知道这个自动加载函数的代码量将会多么大了吧。
如此的话,也会违反了自动加载机制的设计的初衷。所以按照特定的目录结构存放相关的类文件是非常有必要的。
所谓:增加了冗余的特点,却带来了容易维护的好处。
个人觉得,不妨按照Java语言的目录结构来维护PHP程序,这样会有意想不到的收获的。
反射
下面正式进入反射的话题,在摘要部分已经提到。重点就在于ReflectionClass
的使用。
反射属性
<?phprequire './bean/beans.php'; // Person 在beans.php文件中声明$protype = new ReflectionClass("Person"); // 可以添加一个参数,来进行过滤操作。如只获取public类型的属性 $properties = $protype->getProperties(); // 反射获取到类的属性信息 foreach ($properties as $property) { echo $property."<br />"; }
相比于Java,要获取 private
現時点では、この追加の実行方法を PHP インタープリターに知らせる必要があるため、この追加関数を含む A ファイルを
require / include
する必要があります。
このようにして、PHP インタープリターは PHP ファイルを解釈して実行する方法を認識します。
🎜PHP と同様に、Java 言語でもソース ファイルの前に
import
ステートメントを追加するだけで、Java 仮想マシンが関連するクラス情報を自動的に追加できます。さらに、強く型付けされた Java はコンパイル前にそのような問題を検出できるため、コードのメンテナンスがより便利になります。 PHP では手動の include/require
が必要です。 🎜🎜しかし、二人が薬を変えずにスープを変えただけであることは明らかであるはずです。 🎜🎜自動ロードメカニズム🎜🎜しかし、参照される各 php ファイルを手動でロードする場合は、そのようなロードステートメントを複数記述する必要がある場合があります。したがって、この問題への対処を容易にするために、PHP5 以降では自動ロード機構が導入されました。 🎜
<?php require './bean/beans.php'; $protype = new ReflectionClass("Person"); $methods = $protype->getMethods(); foreach ($methods as $method) { echo $method->getName()."<br />"; }🎜
$class
は、ロードされるクラスの名前です。class
の名前であることに注意してください。 🎜使い方は?
🎜自動ローディング機構は非常に優れているので、どのように使用すればよいでしょうか? 🎜🎜その答えは、他のクラス ファイルをロードする必要があるカスタム__autoload($class)
関数を PHP に追加することです。 先ほどのファイル AB を例に考えてみましょう。 🎜🎜ファイル A には person というクラスが記述されており、これはファイル B で使用する必要があります。このとき、ファイル B に __aotoload
関数を追加するだけです。さらに、この関数の記述方法は比較的単純です (すべてが最も単純なアイデアに従って設計されている場合)。 🎜filter过滤结果为仅包含某些属性的方法。默认不过滤。 ReflectionMethod::IS_STATIC、 ReflectionMethod::IS_PUBLIC、 ReflectionMethod::IS_PROTECTED、 ReflectionMethod::IS_PRIVATE、 ReflectionMethod::IS_ABSTRACT、 ReflectionMethod::IS_FINAL 的任意组合。🎜PHP インタープリターは、ファイル B をスキャンするときに最初にチェックします。ターゲット クラス Person が導入されていない場合は、
__autoload
が実装されているかどうかを判断し、存在する場合は、自動ロード機能を使用します。それ以外の場合は、エラーで終了します。 🎜注意事項
🎜上記の自動ロード機能は比較的単純ですが、実際には多くの「価格」が必要です。つまり、ロードされたクラス ファイルの名前がクラスと一致している必要があります (いいえ)大文字と小文字を区別する必要があります)。例: 🎜<?phprequire './bean/beans.php'; $protype = new ReflectionClass ( "Person" ); $properties = $protype->getProperties (); // 反射获取到类的属性信息 foreach ( $properties as $property ) { echo $property . ":"; $doc = $property->getDocComment (); echo " " . $doc . "<br />"; e cho "--------------------------------------------------------" . "<br />"; }$methods = $protype->getMethods(); foreach ($methods as $method) { echo $method->getName()."<br />"; $doc = $method->getDocComment (); echo " " . $doc . "<br />"; echo "--------------------------------------------------------" . "<br />"; }🎜 さらに、この単純な自動ロード機能では、パスの問題も比較的難しい問題ではありません。この条件が満たされない場合の状況を想像してみてください。と、これを知ることができます 自動読み込み機能のコード量は膨大になります。 🎜🎜この場合、自動ローディング機構の本来の目的にも反することになります。したがって、関連するクラス ファイルを特定のディレクトリ構造に従って保存することが非常に必要です。 🎜
🎜いわゆる: 冗長な機能が追加されますが、メンテナンスが容易になるという利点があります。 🎜🎜個人的には、Java 言語のディレクトリ構造に従って PHP プログラムを保守する方が良いと思います。そうすることで、予期せぬ利益が得られるでしょう。 🎜🎜振り返り🎜🎜 ここで、概要セクションで言及した振り返りのトピックに正式に入ります。重要な点は、
ReflectionClass
の使用にあります。 🎜🎜リフレクション属性🎜<?phprequire './bean/beans.php'; $protype = new ReflectionClass ( "Person" );// 模拟数据库中获取到的值,以关联数组的形式抛出 $values = array( "name"=>"郭璞", "age"=> 21, "address"=>"辽宁省大连市");// 开始实例化 $instance = $protype->newInstanceArgs($values); print_r($instance);// var_dump($instance); echo $instance->getName();🎜

private
属性を取得するのが簡単です。 🎜🎜反映方法🎜<?phprequire './bean/beans.php';$classprotype = new ReflectionClass("Grade");$class = $classprotype->newInstanceArgs(array("name"=>"大三")); var_dump($class);echo $class->getName();🎜🎜🎜🎜さらに、フィルター条件を追加することもできます。 getMethods メソッド Tianji にフィルター パラメーターを与えるだけです。 🎜
filter过滤结果为仅包含某些属性的方法。默认不过滤。 ReflectionMethod::IS_STATIC、 ReflectionMethod::IS_PUBLIC、 ReflectionMethod::IS_PROTECTED、 ReflectionMethod::IS_PRIVATE、 ReflectionMethod::IS_ABSTRACT、 ReflectionMethod::IS_FINAL 的任意组合。
反射注释
注释信息,这里就以文档信息为例。
<?phprequire './bean/beans.php'; $protype = new ReflectionClass ( "Person" ); $properties = $protype->getProperties (); // 反射获取到类的属性信息 foreach ( $properties as $property ) { echo $property . ":"; $doc = $property->getDocComment (); echo " " . $doc . "<br />"; e cho "--------------------------------------------------------" . "<br />"; }$methods = $protype->getMethods(); foreach ($methods as $method) { echo $method->getName()."<br />"; $doc = $method->getDocComment (); echo " " . $doc . "<br />"; echo "--------------------------------------------------------" . "<br />"; }
反射实例化
PHPリフレクション技術の詳細なコード例(画像とテキスト)
<?phprequire './bean/beans.php'; $protype = new ReflectionClass ( "Person" );// 模拟数据库中获取到的值,以关联数组的形式抛出 $values = array( "name"=>"郭璞", "age"=> 21, "address"=>"辽宁省大连市");// 开始实例化 $instance = $protype->newInstanceArgs($values); print_r($instance);// var_dump($instance); echo $instance->getName();
反射Grade类
<?phprequire './bean/beans.php';$classprotype = new ReflectionClass("Grade");$class = $classprotype->newInstanceArgs(array("name"=>"大三")); var_dump($class);echo $class->getName();
执行类的方法
$instance->getName(); // 执行Person 里的方法getName// 或者: $method = $class->getmethod('getName'); // 获取Person 类中的getName方法$method->invoke($instance); // 执行getName 方法// 或者:$method = $class->getmethod('setName'); // 获取Person 类中的setName方法$method->invokeArgs($instance, array('snsgou.com'));
总结
回顾一下,本次试验演示了PHP中的反射技术,对比分析了Java语言的反射技术的实现。也只能说各有利弊吧。
在Java中,反射技术是编写框架的基础。虽然在PHP中反射技术不是特别的重要,而且用的时候约束也比较多,稍显鸡肋。但是比葫芦画瓢的话,还是可以做出一些有用的小工具的。
以上がPHPリフレクション技術の詳細なコード例(画像とテキスト)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

セッション関連の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 など) をサポートします。
