PHP Codeigniter 中的_re地圖方法簡介

來源:互聯網
上載者:User
PHP Codeigniter 中的_remap方法簡介
在Codeigniter 中,其實有個容易忽略掉的不錯的控制器層處理的方法,
那就是remap,這裡簡單介紹下。
其實在CI的URL控制方式表示中,比如:
example.com/index.php/blog/comments/

這樣的形式中,blog就是controller,comments就是你的方法了。
又比如參數的傳遞是這樣的:
example.com/index.php/products/shoes/sandals/123

sandals/123就是傳遞的兩個參數了。
URI 的第二片段決定會調用控制器中的哪個方法。CodeIgniter 允許你使用 _remap() 方法來廢除這種規則:

public function _remap()
{
// Some code here...
}

注意:如果你的控制器中包含一個名為 _remap() 的方法,那麼不管你的 URI 中包含什麼,它總會被忽略掉。這個方法會廢除掉由 URI 片段來決定哪個方法被調用的規則,允許你重新定義調用方法的規則(方法的路由規則)。

但問題是,手冊上這樣說的,會有什麼用處呢?其實用處有兩個:
1,改變URL,隱藏方法,比如你的應用中,原來的URL方法是:
http://anmsaiful.net/blog/display_successful_message
現在想改變顯示的方法名為:
http://anmsaiful.net/blog/successful
但顯示雖然是successful,但實際上是調用存在的display_successful_message

方法,這就要用到_remap方法了。

2 還可以借這個函數做簡單的函數方法控制,比如:
public function _remap($method, $params = array())
{
$user_type = $_SESSION['user_type'];
$access_control = $this->validate_access($user_type,$method);
if ($access_control){
$this->$method();
}
else{
$this->show_message();
}
}
首先取出使用者session中的層級 $user_type,然後檢查通過方法
validate_access這個使用者有無許可權調用這個方法($method)
,如果有的話$access_control==true了,否則顯示出錯資訊



1 樓 shirne 2012-04-06

學習了..

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.