PHP架構Laravel的小技巧兩則

來源:互聯網
上載者:User

  這篇文章主要介紹了PHP架構Laravel的小技巧兩則,本文講解了Route::controller中路由批量命名、根據系統變數判斷當前運行環境兩個小技巧,需要的朋友可以參考下

  用 Laravel 作為 PHP 開發架構很久了,但是有些官方文檔中沒有覆蓋到的地方,每隔一段時間又會忘記。最近做了一點簡單的整理,順便記錄下來備忘。

  1. Route::controller 路由命名:

  用 Route::controller 可以減少路由定製中的大量工作,但是有時候需要對某個特定的路由命名以便使用,但是 Route::controller 方法是批量指定了一個 Controller 中所有方法的路由,這要怎麼命名呢?可以用controller($uri, $controller, $names = array()) 中的第三個參數,這是一個數組,數組的 key 是方法,數組的 value 是命名。

  代碼如下:

  // 該函數的簽名:

  public function controller($uri, $controller, $names = array())

  // 不命名一般使用:

  Route::controller('admin', 'AdminController');

  // 需要對其中的部分方法命名的話:

  Route::controller('admin', 'AdminController', array(

  'getIndex' => 'admin.index',

  'getLogin' => 'admin.login',

  'postLogin' => 'admin.login'

  ));

  2. 根據系統變數判斷當前運行環境

  系統預設的判斷是否本地環境的方法是根據在 'local' 數組中指定一組作為本地環境的主機名稱,比如在辦公機、Macbook上都要做開發,你就要把兩個主機名稱都寫進去,我覺得這樣很麻煩。改成了根據 $_SERVER['LARAVEL_ENV'] 來判斷,這樣我可以在所有開發機中都定義 'LARAVEL_ENV' 的環境變數,值為 'local',於是在開發機就會自動識別為 'local' 環境,而其它情況則是 'production'。

  代碼如下:

  // 預設的寫法是根據主機名稱判斷是否本地環境

  $env = $app->detectEnvironment(array(

  'local' => array('homestead');

  ));

  // 修改為先判斷系統變數是否指定,沒有才判斷主機名稱

  $env = $app->detectEnvironment(function(){

  $_env = getenv('LARAVEL_ENV') ? getenv('LARAVEL_ENV') : array(

  'local' => array('homestead')

  );

  return $_env;

  });

  // 這實際是去讀取 $_SERVER['LARAVEL_ENV'] 的值

  // 在 Apache 中,可以用 SetEnv 設定,

 

  // 在 Nginx 中,可以用 fastcgi_param 設定

 
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.