騙されないためのphp set get isset unsetの使い方の分析
皆さんこんにちは、私は Xiaoyan です。今日は不正行為を防ぐための PHP オブジェクト指向の __set __get __isset __unset の使用法を紹介します
全文にご注意ください ============ ========= ================
__set __get __isset __unset これらのメソッドは古いバージョンの PHP でプライベートに設定できますが、設定しないことをお勧めします。現在の PHP バージョンでは、静的に設定することはもちろん、静的メソッドをプライベートに設定すると、正常に値を返すことができますが、警告が表示されます。 ! (php5.5バージョンを使用しています)
本文の始まり=============================== = ======
オブジェクト指向PHPでは__set __get __isset __unsetの使い方をよく見かけますが、なぜこれらが使われるのか分かりません。 以下に一つずつ紹介していきましょう。 4番目の兄弟の使用状況を見てみましょう。
一般に、クラス属性は常にプライベートとして定義され、これはより現実的なロジックに沿ったものです。ただし、属性の読み取りと割り当ての操作は非常に頻繁に行われるため、PHP5 では、属性を取得して割り当てるための 2 つの関数「__get()」と「__set()」、および属性を確認するための「__isset」が事前定義されています。 )」と属性を削除するメソッド「__unset()」。
public function __get($property_name){ if(isset($this->$property_name)){ return($this->$property_name); }else{ return(NULL); }}//__set()方法用来设置私有属性public function __set($property_name, $value){ $this->$property_name = $value;}
基本的に、__get() に関するインターネット上の記事の 99% がこれを述べていますが、最も重要なことは、__get() は現在のクラスのプライベート メンバー変数を取得するだけでなく、このメソッドでは、別のクラスをインスタンス化して別のクラスのオブジェクトを取得するなどの他の操作も実行できます。 以下のコードを見てください
public function __get($name) { return \Libs\Components::getInstance()->$name; }
ここで名前を取得した場合、現在のクラスのプライベート プロパティを取得せず、Components クラスの $name プロパティを静的に呼び出しているわけではないため、__get メソッドは次のようにする必要があります。 __get() メソッドもあり、現在のクラスのプライベート変数を呼び出すだけでなく、取得する変数を指定することもできます。 !
__set() メソッド: このメソッドは、指定した変数を取得するためにも使用されます。最初のパラメーターは、必要な属性です。 name の値を設定する場合、2 番目のパラメータは属性に設定される値であり、戻り値はありません。 ,
__set() メソッドがない場合、$this->name='zhangsan' のようにプライベート変数を直接取得することはできません。これはエラーになりますが、__set() を追加すると、クラス $property_name, $value) $property_name に name などの属性を渡し、$value に代入する値 "zhangsan" を渡すと、このメソッドが自動的に呼び出されます。メソッド 代入の目的を達成するために実行します。メンバーのプロパティがプライベートとしてカプセル化されていない場合、オブジェクト自体はこのメソッドを自動的に呼び出しません。不正な値を渡さないように、このメソッドで判定することもできます。コードは以下の通りです:
public function __get($name) { if(isset($this->config[$name])) { return $this->config[$name]; } return null; }
<?php class Person{ private $name; private $sex; private $age; private function __get($property_name){ echo "在直接获取私有属性值的时候,自动调用了这个__get()方法<br>"; if (isset($this->$property_name)) { return ($this->$property_name); } else { return null; } } private function __set($property_name, $value) { echo "在直接设置私有属性值的时候,自动调用了这个__set()方法为私有属性赋值<br>"; $this->$property_name = $value; }}$p1 = new Person();$p1->name = "小烟";$p1->sex = "男";$p1->age = 23;echo "姓名:".$p1->name."<br>";echo "性别:".$p1->sex."<br>";echo "年龄:".$p1->age."<br>";
上記のコードで __get() メソッドと __set() メソッドが追加されていない場合、プライベート操作が実行できないためプログラムはエラーになります。上記のコードは、__get() メソッドと __set() メソッドを自動的に呼び出すことで、カプセル化されたプライベート メンバーに直接アクセスするのに役立ちます。
__isset() メソッド: このメソッドを説明する前に、「isset()」関数の応用を見てみましょう。 isset() は、変数が設定されているかどうかを判断するために使用される関数です。 If 入力された変数が存在する場合は true を返し、それ以外の場合は false を返します。
那么如果在一个对象外面使用"isset()"这个函数去测定对象里面的成员是否被设定可不可以用它呢?分两种情况,如果对象里面成员是公有的,我们就可以使用这个函数来测定成员属性,如果是私有的成员属性,这个函数就不起作用了,原因就是因为私有的被封装了,在外部不可见。那么我们就不可以在对象的外部使用"isset()"函数来测定私有成员属性是否被设定了呢?
答案是可以的,你只要在类里面加上一个"__isset()"方法就可以了,当在类外部使用"isset()"函数来测定对象里面的私有成员是否被设定时,就会自动调用类里面的"__isset()"方法了帮我们完成这样的操作,"__isset()"方法也可以做成私有的。你可以在类里面加上下面这样的代码就可以了:
private function __isset($nm){ echo "当在类外部使用isset()函数测定私有成员$nm时,自动调用<br>"; return isset($this->$nm);}
__unset()方法:看这个方法之前呢,我们也先来看一下"unset()"这个函数,"unset()"这个函数的作用是删除指定的变量且传回true,参数为要删除的变量。那么如果在一个对象外部去删除对象内部的成员属性用"unset()"函数可不可以呢,也是分两种情况,如果一个对象里面的成员属性是公有的,就可以使用这个函数在对象外面删除对象的公有属性,如果对象的成员属性是私有的,我使用这个函数就没有权限去删除,但同样如果你在一个对象里面加上"__unset()"这个方法,就可以在对象的外部去删除对象的私有成员属性了。
在对象里面加上了"__unset()"这个方法之后,在对象外部使用"unset()"函数删除对象内部的私有成员属性时,自动调用"__unset()"函数来帮
我们删除对象内部的私有成员属性,这个方法也可以在类的内部定义成私有的。在对象里面加上下面的代码就可以了:
private function __unset($nm){ echo "当在类外部使用unset()函数来删除私有成员时自动调用的<br>"; unset($this->$nm);}
最后,我们来看一个完整的实例:
<?phpclass Person { private $name; private $sex; private $age; public function __get($property_name) { if(isset($this->$property_name)) { return ($this->$property_name); } else { return (NULL); } } public function __set($property_name, $value) { $this->$property_name = $value; } public function __isset($nm) { echo "isset()函数测定私有成员时,自动调用<br>"; return isset($this->$nm); } public function __unset($nm) { echo "当在类外部使用unset()函数来删除私有成员时自动调用的<br>"; unset($this->$nm); }}$p1 = new Person();$p1->name = "this is a person name";echo var_dump(isset($p1->name))."<br>";echo $p1->name."<br>";unset($p1->name);echo $p1->name;
isset()函数测定私有成员时,自动调用
bool(true)
this is a person name
当在类外部使用unset()函数来删除私有成员时自动调用的
isset()函数测定私有成员时,自动调用
最后最后 小烟还是要提醒下你 这四个方法用法都是非常的灵活的 不要以为只能获取类里面的私有变量 而且可以自由扩展 获取类里某个特定成员变量的值 或者 其他类里面的值 切记切记 不要被误导!!

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

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

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

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

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

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

ホットトピック









Laravelは、直感的なフラッシュメソッドを使用して、一時的なセッションデータの処理を簡素化します。これは、アプリケーション内に簡単なメッセージ、アラート、または通知を表示するのに最適です。 データは、デフォルトで次の要求のためにのみ持続します。 $リクエスト -

PHPクライアントURL(CURL)拡張機能は、開発者にとって強力なツールであり、リモートサーバーやREST APIとのシームレスな対話を可能にします。尊敬されるマルチプロトコルファイル転送ライブラリであるLibcurlを活用することにより、PHP Curlは効率的なexecuを促進します

Laravelは簡潔なHTTP応答シミュレーション構文を提供し、HTTP相互作用テストを簡素化します。このアプローチは、テストシミュレーションをより直感的にしながら、コード冗長性を大幅に削減します。 基本的な実装は、さまざまな応答タイプのショートカットを提供します。 Illuminate \ support \ facades \ httpを使用します。 http :: fake([[ 'google.com' => 'hello world'、 'github.com' => ['foo' => 'bar']、 'forge.laravel.com' =>

顧客の最も差し迫った問題にリアルタイムでインスタントソリューションを提供したいですか? ライブチャットを使用すると、顧客とのリアルタイムな会話を行い、すぐに問題を解決できます。それはあなたがあなたのカスタムにより速いサービスを提供することを可能にします

記事では、PHP 5.3で導入されたPHPの後期静的結合(LSB)について説明し、より柔軟な継承を求める静的メソッドコールのランタイム解像度を可能にします。 LSBの実用的なアプリケーションと潜在的なパフォーマ

この記事では、フレームワークにカスタム機能を追加し、アーキテクチャの理解、拡張ポイントの識別、統合とデバッグのベストプラクティスに焦点を当てています。

記事では、入力検証、認証、定期的な更新など、脆弱性から保護するためのフレームワークの重要なセキュリティ機能について説明します。
