10大技巧

若是你使用一面大鏡子做爲衝浪板會發生什麼?或許你會在較短的時間內征服海浪,可是你確定從心裏深處明白,這不是衝浪的正確選擇。一樣的道理也適用於PHP編程,儘管這樣的類比聽起來有一些古怪。咱們常常聽到有人試圖用一個週末多點的時間來學會PHP,可是請恕我直言,這是學習這門編程語言的一種很是糟糕的方式。
爲什麼說學習PHP的過程有別於任何其它語言?
就其本質而言,若是你掌握了以PHP語言「作事」的方式,那麼在使用它時就會駕輕就熟,所以值得你去投入精力去了解這些方式。在PHP中,單純按照本身思路去解決問題每每會是一種錯誤的辦法。這並非由於你是一個糟糕的程序員,而是由於若是你想寫出好的可維護性強的代碼,有些標準技巧是你必需要使用的。下面讓咱們一塊兒看一下你須要知道的10大技巧。
一、如何正確的建立一個網站的Index頁面
建立每個網站時,創建網站的index頁面是首要作的事情之一。若是你是一個PHP新手,在編寫index頁面時典型的作法是隻對index頁面所需的內容進行編程,其它連接建立另外一個頁面。不過,若是想學習一種更高效的方式來實現PHP編程,能夠採用「index.php?page=home」模式,許多網站都在採用這種模式。
二、使用Request Global Array抓取數據
實際上咱們沒有任何理由使用$_GET和$_POST數組來抓取數值。$_REQUEST這個全局數組可以讓你獲取一個get或form請求。所以,多數狀況下解析數據的更高效代碼大致以下:
  
  
           
  
  
  1. $action = isset($_REQUEST['action']) ? $_REQUEST['action'] : 0;  
三、利用var_dump進行PHP代碼調試
若是你在尋找php調試技術,我必須說var_dump應該是你要找的目標。在顯示php信息方面這個命令能夠知足你的全部須要。而調試代碼的多數狀況與獲得PHP中的數值有關。
四、PHP處理代碼邏輯,Smarty處理展示層
Smarty是一個使用PHP寫出來的模板PHP模板引擎,是目前業界最著名的PHP模板引擎之一。它分離了邏輯代碼和外在的內容,提供了一種易於管理和使用的方法,用來將本來與HTML代碼混雜在一塊兒PHP代碼邏輯分離。簡單的講,目的就是要使PHP程序員同前端人員分離,使程序員改變程序的邏輯內容不會影響到前端人員的頁面設計,前端人員從新修改頁面不會影響到程序的程序邏輯,這在多人合做的項目中顯的尤其重要。
五、的確須要使用全局數值時,建立一個Config文件
動輒建立全局數值是一種糟糕的作法,不過有時候實際狀況的確又須要這麼作。對於數據庫表或數據庫鏈接信息使用全局數值是一個不錯的想法,但不要在你的PHP代碼中頻繁使用全局數值。另外,更好的一種作法是把你的全局變量存放在一個config.php文件中。
六、若是未定義,禁止訪問!
若是你正確的建立了頁面,那麼任何其餘人沒有理由訪問index.php或home.php以外的index.php頁面。一旦index.php被訪問後,你能夠經過得到變量的方式來打開須要的頁面。你的index頁面應該包含相似的如下代碼:
  
  
           
  
  
  1. define('yourPage',1); 
而後,其它頁面應該包含:
  
  
           
  
  
  1. if (!defined('yourPage')) die('Access Denied'); 
這麼作的目的是防止直接訪問你的其它php頁面。這樣,任何試圖不經過index.php訪問其它網頁的人,將獲得「訪問被拒絕」的消息。
七、建立一個數據庫類
若是你正在進行數據庫編程(在PHP中很是常見的任務),一個不錯的想法是建立一個數據庫類來處理任何數據庫管理功能。示例代碼以下:
  
  
           
  
  
  1. public function dbExec($query)    
  2.  
  3.  {    
  4.  
  5.      $result = $this->db->exec($query);    
  6.  
  7.      if (PEAR::isError($result))    
  8.  
  9.          errorRedirect($result->getMessage(), true);    
  10.  
  11.      else   
  12.  
  13.          return $result;    
  14.  
  15.  }  
這個函數僅接收一個查詢語句並對其執行。它還處理可能出現的任何錯誤。你還能夠在這兒包含審覈代碼,不過我更喜歡使用一個相似的審覈函數:
  
  
           
  
  
  1. // checks if arguments given are integer values not less than 0 - has multiple arguments    
  2.  
  3.  function sanitizeInput()    
  4.  
  5.  {    
  6.  
  7.      $numargs = func_num_args();    
  8.  
  9.      $arg_list = func_get_args();    
  10.  
  11.      for ($i = 0; $i < $numargs$i++) {    
  12.  
  13.          if (!is_numeric($arg_list[$i]) || $arg_list[$i] < 0)    
  14.  
  15.              errorRedirect("Unexpected variable value", true);    
  16.  
  17.      }    
  18.  
  19.  }  
八、一個php文件處理輸入,一個class.php文件處理具體功能
不讓代碼變得混亂的一個重要方法是:獲取用戶輸入後,將其重定向到其它函數來進行處理。原理很是簡單,php文件得到咱們須要的任何輸入,而後將其執行重定向到類文件中的一個函數。舉例來說,假設有一個相似「index.php?page=profile&action=display」的URL。由profile.php來檢索該網址並獲得操做是「display」。而後使用一個簡單的switch函數,咱們來執行真正的顯示函數:
  
  
           
  
  
  1. require_once PROJECTROOT.'libs/messages.class.php';     
  2.  
  3. $message = new Message();     
  4.  
  5. switch ($action)   
  6.  
  7. {   
  8.  
  9.     case 'display':   
  10.  
  11.         $message->display();   
  12.  
  13.         break;     
  14.  
  15. ... 
如上所示,我使用了一個消息類,而後開始進行switch檢查。$message只是被類中的調用函數使用的一個對象。
九、瞭解你的SQL語句,並老是對其審查(Sanitize)
正如我之前所提到的,任何php網站中最重要的部分有99%的多是數據庫。所以,你須要很是熟悉如何正確的使用sql。學會關聯表和更多高級技術。下面我將展現一個使用MySQL的函數示例,並使用本文第7條函數進行審查。
  
  
           
  
  
  1. private function getSentMessages($id)    
  2.  
  3.  {    
  4.  
  5. $this->util->sanitizeInput($id);    
  6.  
  7.     $pm_table = $GLOBALS['config']['privateMsg'];    
  8.  
  9.  $users = $GLOBALS['config']['users'];    
  10.  
  11.      $sql = "SELECT PM.*, USR.username as name_sender FROM $pm_table PM, $users USR    
  12.  
  13.          WHERE id_sender = '$id' AND sender_purge = FALSE AND USR.id = PM.id_receiver AND is_read = TRUE    
  14.  
  15.          ORDER BY date_sent DESC";    
  16.  
  17.  $result = $this->dbQueryAll($sql);    
  18.  
  19.     return $result;    
  20.  
  21.  }  
首先,咱們對用戶輸入進行檢查(經過一個GET變量傳遞消息id),而後咱們執行咱們的SQL命令。注意這兒SQL的用法。你須要瞭解如何使用別名和關聯表。
十、當你只須要一個對象時,使用單例模式
在PHP中至關常見的一種情形時,咱們只須要建立一個對象一次,而後在咱們的整個程序中使用它。一個很好的例子就是smarty變量,一旦被初始化後就能夠在任何地方使用。這種情形的一個很好實現方案就是單例模式。示例代碼以下:
  
  
           
  
  
  1. function smartyObject()    
  2.  
  3.  {    
  4.  
  5.      if ($GLOBALS['config']['SmartyObj'] == 0)    
  6.  
  7.      {    
  8.  
  9.          $smarty = new SmartyGame();    
  10.  
  11.          $GLOBALS['config']['SmartyObj'] = $smarty;    
  12.  
  13.      }    
  14.  
  15.      else   
  16.  
  17.          $smarty = $GLOBALS['config']['SmartyObj'];    
  18.  
  19.      return $smarty;    
  20.  
  21.  }  
注意,咱們擁有一個全局smarty變量(該示例中它在config.php中被初始化),若是它的值爲0,咱們將建立一個新smarty對象。不然,它意味着該對象已經被建立,咱們只須要返回它。
相關文章
相關標籤/搜索