您好,登錄后才能下訂單哦!
這篇文章主要講解了“php代理模式和外觀設計模式分別是什么”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“php代理模式和外觀設計模式分別是什么”吧!
Proxy(代理模式)和Facade(外觀)設計模式 它們均為更復雜的功能提供抽象化的概念,但這兩種實現抽象化的過程大不相同
Proxy(代理模式)和Facade(外觀)設計模式
它們均為更復雜的功能提供抽象化的概念,但這兩種實現抽象化的過程大不相同
Proxy案例中,所有的方法和成員變量都來自于目標對象,必要時,該代理能夠對它所傳遞的數據進行修改或檢查
魔術方法使得Proxy的實現變的簡單,Proxy模式的一類應用時用來記錄方法的訪問信息
還可以利用Proxy的類確定代碼的范圍或調試程序中存在的問題
<?phpclass LoggingProxy{ private $target; //傳遞進去一個對象 public function __construct($target){ $this->target=$target; } protected function log($line){ echo "[".$line."]\r\n"; } public function __set($name,$value){ $this->target->$name=$value; $this->log("setting value for $name:$value "); } public function __get($name){ $value=$this->target->$name; $this->log("Getting value for $name:$value"); return $value; } public function __isset($name){ $value=isset($this->target->$name); $this->log("checking isset for $name".($value?"true":"false")); return $value; } public function __call($name,$arguments){ $this->log("calling method $name width:".implode(",", $arguments)); return call_user_func_array(array($this->target,$name), $arguments); } }class People{ public $name='hk'; public $age; public function sayname(){ return $this->name; } public function plus($a,$b){ return $a+$b; } }$p=new People();$proxy=new LoggingProxy($p);echo $proxy->name;//hkecho " ";$proxy->age=10;echo $p->age;//10echo " ";echo $proxy->sayname();echo " ";echo $proxy->plus(2,3);
結果
[Getting value for name:hk] hk
[setting value for age:10 ] 10
[calling method sayname width:] hk
[calling method plus width:2,3] 5
多數情況下Proxy不應該改變它所代理的類的行為
Proxy與它所代理的在類型上不完全一致,這也是其一個缺點。
因而若需要進行類型提示或代碼檢查以確保對象是某一特定類型,這種情況下就不能使用代理模式三門峽婦科醫院http://www.smxrlyy.com/
Facade(外觀)模式提供了不同的功能,用來抽象化復雜功能,以使應用程序無需了解子系統處理
各請求的細節,就能完成整個處理過程
例如:處理典型api請求時,用戶需要通過子系統進行認證,認證通過后,請求通過api子系統傳遞給遠程服務器
處理,最后通過其它api的函數對相應解碼
Facade方法粗略實現如下
<?phpclass Facade{ public function apiRequestJson($method,$parameters){ $user=User::getAuthenticatedUser(); if($user->hasPermission($method)){ $result=$this->api->$method($parameters); return json_encode($result); } } }
Facade并不為子系統添加任何新的功能,而是為子系統委托合適的責任。
子系統無需知道Facade的存在,而應用程序也無需知道子系統的存在。
下面代碼,沒使用外觀模式前
<?phpfunction getProductFileLines($file){ return file($file); }function getProductObjectFromId($id,$productname){ return new Product($id,$productname); }function getNameFromLine($line){ if(preg_match('#.*-(.*)\s\d+#', $line,$array)){ return str_replace('_', ' ', $array[1]); } return ''; }function getIdFromLine($line){ if(preg_match('#^(\d{1,3})-#', $line,$arr)){ return $arr[1]; } return -1; }class Product{ public $id; public $name; public function __construct($id,$name){ $this->id=$id; $this->name=$name; } }$lines=getProductFileLines('t.txt');$objects=array();foreach ($lines as $line){ $id=getIdFromLine($line); $name=getNameFromLine($line); $objects[$id]=getProductObjectFromId($id, $name); }
t.txt內容
234-ladies_jumper 55532-gents_hat 44
如果像以上代碼調用子系統,我們的代碼和子系統緊緊耦合在一起,當子系統變化時,或者我們決定將其與子系統完全斷開時,代碼就會出問題,所以我們需要在
這些子系統和代碼中引入一個入口。
class ProductFacade{ private $products=array(); public function __construct($file){ $this->file=$file; $this->compile(); } private function compile(){ $lines=getProductFileLines($this->file); foreach ($lines as $line){ $id=getIdFromLine($line); $name=getNameFromLine($line); $this->products[$id]=getProductObjectFromId($id, $name); } } public function getProducts(){ return $this->products; } public function getProduct($id){ return $this->products[$id]; } }$facade=new ProductFacade('t.txt');echo $facade->getProduct(234)->name;
感謝各位的閱讀,以上就是“php代理模式和外觀設計模式分別是什么”的內容了,經過本文的學習后,相信大家對php代理模式和外觀設計模式分別是什么這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。