本文實例講述了PHP的攔截器用法。分享給大家供大家參考。具體如下:
PHP提供了幾個攔截器,用於在訪問未定義的方法和屬性時被調用,如下所示:
1、__get($property)
功能:訪問未定義的屬性是被調用
2、__set($property, $value)
功能:給未定義的屬性設置值時被調用
3、__isset($property)
功能:對未定義的屬性調用isset()時被調用
4、__unset($property)
功能:對未定義的屬性調用unset()時被調用
5、__call($method, $arg_array)
功能:調用未定義的方法時被調用
下面將通過一個小程序來說明這些攔截器的用途:
復制代碼 代碼如下:class intercept_demo{
private $xingming = "";
private $age = 10;
// 若訪問一個未定義的屬性,則將調用get{$property}對應的方法
function __get($property){
$method = "get{$property}";
if (method_exists($this, $method)){
return $this->$method();
}
}
// 若給一個未定義的屬性設置值,則將調用set{$property}對應的方法
function __set($property, $value){
$method = "set{$property}";
if (method_exists($this, $method)){
return $this->$method($value);
}
}
// 若用戶對未定義的屬性調用isset方法,
function __isset($property){
$method = "isset{$property}";
if (method_exists($this, $method)){
return $this->$method();
}
}
// 若用戶對未定義的屬性調用unset方法,
// 則認為調用對應的unset{$property}方法
function __unset($property){
$method = "unset{$property}";
if (method_exists($this, $method)){
return $this->$method();
}
}
function __call($method, $arg_array){
if (substr($method,0,3)=="get"){
$property = substr($method,3);
$property = strtolower(substr($property,0,1)).substr($property,1);
return $this->$property;
}
}
function testIsset(){
return isset($this->Name);
}
function getName(){
return $this->xingming;
}
function setName($value){
$this->xingming = $value;
}
function issetName(){
return !is_null($this->xingming);
}
function unsetName(){
$this->xingming = NULL;
}
}
$intercept = new intercept_demo();
echo "設置屬性Name為Li";
$intercept->Name = "Li";
echo "\$intercept->Name={$intercept->Name}";
echo "isset(Name)={$intercept->testIsset()}";
echo "";
echo "清空屬性Name值";
unset($intercept->Name);
echo "\$intercept->Name={$intercept->Name}";
echo "";
echo "調用未定義的getAge函數";
echo "age={$intercept->getAge()}";
希望本文所述對大家的PHP程序設計有所幫助。
就是幾個$_SERVER的變量
$url = 'http://'.$_SERVER['HTTP_HOST'].$_SERVER['REQUEST_URI'];
echo $url;
這兩個就是你想要的東東..
攔截器有攔截器不可替代的功能,攔截器可以集體處理及存儲變量,而公共屬性並不好,你如果常用公共屬性,你的面向對象思維都沒了.老大.