讓PHP開發(fā)者事半功倍的十大技巧小結(jié)
更新時間:2010年04月20日 21:48:52 作者:
在PHP中,單純按照自己思路去解決問題往往會是一種錯誤的辦法。這并不是因為你是一個糟糕的程序員,而是因為如果你想寫出好的可維護性強的代碼,有些標(biāo)準(zhǔn)技巧是你必須要使用的。
如果你使用一面大鏡子作為沖浪板會發(fā)生什么?或許你會在較短的時間內(nèi)征服海浪,但是你肯定從內(nèi)心深處明白,這不是沖浪的正確選擇。同樣的道理也適用于PHP編程,盡管這樣的類比聽起來有一些古怪。我們經(jīng)常聽到有人試圖用一個周末多點的時間來學(xué)會PHP,但是請恕我直言,這是學(xué)習(xí)這門編程語言的一種非常糟糕的方式。
為何說學(xué)習(xí)PHP的過程有別于任何其它語言?
就其本質(zhì)而言,如果你掌握了以PHP語言“做事”的方式,那么在使用它時就會得心應(yīng)手,因此值得你去投入精力去了解這些方式。在PHP中,單純按照自己思路去解決問題往往會是一種錯誤的辦法。這并不是因為你是一個糟糕的程序員,而是因為如果你想寫出好的可維護性強的代碼,有些標(biāo)準(zhǔn)技巧是你必須要使用的。下面讓我們一起看一下你需要知道的10大技巧。
1、如何正確的創(chuàng)建一個網(wǎng)站的Index頁面
創(chuàng)建每一個網(wǎng)站時,建立網(wǎng)站的index頁面是首要做的事情之一。如果你是一個PHP新手,在編寫index頁面時典型的做法是只對index頁面所需的內(nèi)容進行編程,其它鏈接創(chuàng)建另一個頁面。不過,如果想學(xué)習(xí)一種更高效的方式來實現(xiàn)PHP編程,可以采用“index.php?page=home”模式,許多網(wǎng)站都在采用這種模式。
2、使用Request Global Array抓取數(shù)據(jù)
實際上我們沒有任何理由使用$_GET和$_POST數(shù)組來抓取數(shù)值。$_REQUEST這個全局數(shù)組能夠讓你獲取一個get或form請求。因此,多數(shù)情況下解析數(shù)據(jù)的更高效代碼大體如下:
$action = isset($_REQUEST['action']) ? $_REQUEST['action'] : 0;
3、利用var_dump進行PHP代碼調(diào)試
如果你在尋找php調(diào)試技術(shù),我必須說var_dump應(yīng)該是你要找的目標(biāo)。在顯示php信息方面這個命令可以滿足你的所有需要。而調(diào)試代碼的多數(shù)情況與得到PHP中的數(shù)值有關(guān)。
4、PHP處理代碼邏輯,Smarty處理展現(xiàn)層
Smarty是一個使用PHP寫出來的模板PHP模板引擎,是目前業(yè)界最著名的PHP模板引擎之一。它分離了邏輯代碼和外在的內(nèi)容,提供了一種易于管理和使用的方法,用來將原本與HTML代碼混雜在一起PHP代碼邏輯分離。簡單的講,目的就是要使PHP程序員同前端人員分離,使程序員改變程序的邏輯內(nèi)容不會影響到前端人員的頁面設(shè)計,前端人員重新修改頁面不會影響到程序的程序邏輯,這在多人合作的項目中顯的尤為重要。
5、的確需要使用全局數(shù)值時,創(chuàng)建一個Config文件
動輒創(chuàng)建全局數(shù)值是一種糟糕的做法,不過有時候?qū)嶋H情況的確又需要這么做。對于數(shù)據(jù)庫表或數(shù)據(jù)庫連接信息使用全局數(shù)值是一個不錯的想法,但不要在你的PHP代碼中頻繁使用全局數(shù)值。另外,更好的一種做法是把你的全局變量存放在一個config.php文件中。
6、如果未定義,禁止訪問!
如果你正確的創(chuàng)建了頁面,那么任何其他人沒有理由訪問index.php或home.php之外的index.php頁面。一旦index.php被訪問后,你可以通過獲得變量的方式來打開需要的頁面。你的index頁面應(yīng)該包含類似的以下代碼:
define('yourPage',1);
然后,其它頁面應(yīng)該包含:
if (!defined('yourPage')) die('Access Denied');
這么做的目的是防止直接訪問你的其它php頁面。這樣,任何試圖不通過index.php訪問其它網(wǎng)頁的人,將得到“訪問被拒絕”的消息。
7、創(chuàng)建一個數(shù)據(jù)庫類
如果你正在進行數(shù)據(jù)庫編程(在PHP中非常常見的任務(wù)),一個不錯的想法是創(chuàng)建一個數(shù)據(jù)庫類來處理任何數(shù)據(jù)庫管理功能。示例代碼如下:
public function dbExec($query)
{
$result = $this->db->exec($query);
if (PEAR::isError($result))
errorRedirect($result->getMessage(), true);
else
return $result;
}
這個函數(shù)僅接收一個查詢語句并對其執(zhí)行。它還處理可能出現(xiàn)的任何錯誤。你還可以在這兒包含審核代碼,不過我更喜歡使用一個類似的審核函數(shù):
// checks if arguments given are integer values not less than 0 - has multiple arguments
function sanitizeInput()
{
$numargs = func_num_args();
$arg_list = func_get_args();
for ($i = 0; $i < $numargs; $i++) {
if (!is_numeric($arg_list[$i]) || $arg_list[$i] < 0)
errorRedirect("Unexpected variable value", true);
}
}
8、一個php文件處理輸入,一個class.php文件處理具體功能
不讓代碼變得混亂的一個重要方法是:獲取用戶輸入后,將其重定向到其它函數(shù)來進行處理。原理非常簡單,php文件獲得我們需要的任何輸入,然后將其執(zhí)行重定向到類文件中的一個函數(shù)。舉例來講,假設(shè)有一個類似“index.php?page=profile&action=display”的URL。由profile.php來檢索該網(wǎng)址并得到操作是“display”。然后使用一個簡單的switch函數(shù),我們來執(zhí)行真正的顯示函數(shù):
require_once PROJECTROOT.'libs/messages.class.php';
$message = new Message();
switch ($action)
{
case 'display':
$message->display();
break;
...
如上所示,我使用了一個消息類,然后開始進行switch檢查。$message只是被類中的調(diào)用函數(shù)使用的一個對象。
9、了解你的SQL語句,并總是對其審查(Sanitize)
正如我以前所提到的,任何php網(wǎng)站中最重要的部分有99%的可能是數(shù)據(jù)庫。因此,你需要非常熟悉如何正確的使用sql。學(xué)會關(guān)聯(lián)表和更多高級技術(shù)。下面我將展示一個使用MySQL的函數(shù)示例,并使用本文第7條函數(shù)進行審查。
private function getSentMessages($id)
{
$this->util->sanitizeInput($id);
$pm_table = $GLOBALS['config']['privateMsg'];
$users = $GLOBALS['config']['users'];
$sql = "SELECT PM.*, USR.username as name_sender FROM $pm_table PM, $users USR
WHERE id_sender = '$id' AND sender_purge = FALSE AND USR.id = PM.id_receiver AND is_read = TRUE
ORDER BY date_sent DESC";
$result = $this->dbQueryAll($sql);
return $result;
}
首先,我們對用戶輸入進行檢查(通過一個GET變量傳遞消息id),然后我們執(zhí)行我們的SQL命令。注意這兒SQL的用法。你需要了解如何使用別名和關(guān)聯(lián)表。
10、當(dāng)你只需要一個對象時,使用單例模式
在PHP中相當(dāng)常見的一種情形時,我們只需要創(chuàng)建一個對象一次,然后在我們的整個程序中使用它。一個很好的例子就是smarty變量,一旦被初始化后就可以在任何地方使用。這種情形的一個很好實現(xiàn)方案就是單例模式。示例代碼如下:
function smartyObject()
{
if ($GLOBALS['config']['SmartyObj'] == 0)
{
$smarty = new SmartyGame();
$GLOBALS['config']['SmartyObj'] = $smarty;
}
else
$smarty = $GLOBALS['config']['SmartyObj'];
return $smarty;
}
注意,我們擁有一個全局smarty變量(該示例中它在config.php中被初始化),如果它的值為0,我們將創(chuàng)建一個新smarty對象。否則,它意味著該對象已經(jīng)被創(chuàng)建,我們只需要返回它。
為何說學(xué)習(xí)PHP的過程有別于任何其它語言?
就其本質(zhì)而言,如果你掌握了以PHP語言“做事”的方式,那么在使用它時就會得心應(yīng)手,因此值得你去投入精力去了解這些方式。在PHP中,單純按照自己思路去解決問題往往會是一種錯誤的辦法。這并不是因為你是一個糟糕的程序員,而是因為如果你想寫出好的可維護性強的代碼,有些標(biāo)準(zhǔn)技巧是你必須要使用的。下面讓我們一起看一下你需要知道的10大技巧。
1、如何正確的創(chuàng)建一個網(wǎng)站的Index頁面
創(chuàng)建每一個網(wǎng)站時,建立網(wǎng)站的index頁面是首要做的事情之一。如果你是一個PHP新手,在編寫index頁面時典型的做法是只對index頁面所需的內(nèi)容進行編程,其它鏈接創(chuàng)建另一個頁面。不過,如果想學(xué)習(xí)一種更高效的方式來實現(xiàn)PHP編程,可以采用“index.php?page=home”模式,許多網(wǎng)站都在采用這種模式。
2、使用Request Global Array抓取數(shù)據(jù)
實際上我們沒有任何理由使用$_GET和$_POST數(shù)組來抓取數(shù)值。$_REQUEST這個全局數(shù)組能夠讓你獲取一個get或form請求。因此,多數(shù)情況下解析數(shù)據(jù)的更高效代碼大體如下:
$action = isset($_REQUEST['action']) ? $_REQUEST['action'] : 0;
3、利用var_dump進行PHP代碼調(diào)試
如果你在尋找php調(diào)試技術(shù),我必須說var_dump應(yīng)該是你要找的目標(biāo)。在顯示php信息方面這個命令可以滿足你的所有需要。而調(diào)試代碼的多數(shù)情況與得到PHP中的數(shù)值有關(guān)。
4、PHP處理代碼邏輯,Smarty處理展現(xiàn)層
Smarty是一個使用PHP寫出來的模板PHP模板引擎,是目前業(yè)界最著名的PHP模板引擎之一。它分離了邏輯代碼和外在的內(nèi)容,提供了一種易于管理和使用的方法,用來將原本與HTML代碼混雜在一起PHP代碼邏輯分離。簡單的講,目的就是要使PHP程序員同前端人員分離,使程序員改變程序的邏輯內(nèi)容不會影響到前端人員的頁面設(shè)計,前端人員重新修改頁面不會影響到程序的程序邏輯,這在多人合作的項目中顯的尤為重要。
5、的確需要使用全局數(shù)值時,創(chuàng)建一個Config文件
動輒創(chuàng)建全局數(shù)值是一種糟糕的做法,不過有時候?qū)嶋H情況的確又需要這么做。對于數(shù)據(jù)庫表或數(shù)據(jù)庫連接信息使用全局數(shù)值是一個不錯的想法,但不要在你的PHP代碼中頻繁使用全局數(shù)值。另外,更好的一種做法是把你的全局變量存放在一個config.php文件中。
6、如果未定義,禁止訪問!
如果你正確的創(chuàng)建了頁面,那么任何其他人沒有理由訪問index.php或home.php之外的index.php頁面。一旦index.php被訪問后,你可以通過獲得變量的方式來打開需要的頁面。你的index頁面應(yīng)該包含類似的以下代碼:
define('yourPage',1);
然后,其它頁面應(yīng)該包含:
if (!defined('yourPage')) die('Access Denied');
這么做的目的是防止直接訪問你的其它php頁面。這樣,任何試圖不通過index.php訪問其它網(wǎng)頁的人,將得到“訪問被拒絕”的消息。
7、創(chuàng)建一個數(shù)據(jù)庫類
如果你正在進行數(shù)據(jù)庫編程(在PHP中非常常見的任務(wù)),一個不錯的想法是創(chuàng)建一個數(shù)據(jù)庫類來處理任何數(shù)據(jù)庫管理功能。示例代碼如下:
復(fù)制代碼 代碼如下:
public function dbExec($query)
{
$result = $this->db->exec($query);
if (PEAR::isError($result))
errorRedirect($result->getMessage(), true);
else
return $result;
}
這個函數(shù)僅接收一個查詢語句并對其執(zhí)行。它還處理可能出現(xiàn)的任何錯誤。你還可以在這兒包含審核代碼,不過我更喜歡使用一個類似的審核函數(shù):
復(fù)制代碼 代碼如下:
// checks if arguments given are integer values not less than 0 - has multiple arguments
function sanitizeInput()
{
$numargs = func_num_args();
$arg_list = func_get_args();
for ($i = 0; $i < $numargs; $i++) {
if (!is_numeric($arg_list[$i]) || $arg_list[$i] < 0)
errorRedirect("Unexpected variable value", true);
}
}
8、一個php文件處理輸入,一個class.php文件處理具體功能
不讓代碼變得混亂的一個重要方法是:獲取用戶輸入后,將其重定向到其它函數(shù)來進行處理。原理非常簡單,php文件獲得我們需要的任何輸入,然后將其執(zhí)行重定向到類文件中的一個函數(shù)。舉例來講,假設(shè)有一個類似“index.php?page=profile&action=display”的URL。由profile.php來檢索該網(wǎng)址并得到操作是“display”。然后使用一個簡單的switch函數(shù),我們來執(zhí)行真正的顯示函數(shù):
復(fù)制代碼 代碼如下:
require_once PROJECTROOT.'libs/messages.class.php';
$message = new Message();
switch ($action)
{
case 'display':
$message->display();
break;
...
如上所示,我使用了一個消息類,然后開始進行switch檢查。$message只是被類中的調(diào)用函數(shù)使用的一個對象。
9、了解你的SQL語句,并總是對其審查(Sanitize)
正如我以前所提到的,任何php網(wǎng)站中最重要的部分有99%的可能是數(shù)據(jù)庫。因此,你需要非常熟悉如何正確的使用sql。學(xué)會關(guān)聯(lián)表和更多高級技術(shù)。下面我將展示一個使用MySQL的函數(shù)示例,并使用本文第7條函數(shù)進行審查。
復(fù)制代碼 代碼如下:
private function getSentMessages($id)
{
$this->util->sanitizeInput($id);
$pm_table = $GLOBALS['config']['privateMsg'];
$users = $GLOBALS['config']['users'];
$sql = "SELECT PM.*, USR.username as name_sender FROM $pm_table PM, $users USR
WHERE id_sender = '$id' AND sender_purge = FALSE AND USR.id = PM.id_receiver AND is_read = TRUE
ORDER BY date_sent DESC";
$result = $this->dbQueryAll($sql);
return $result;
}
首先,我們對用戶輸入進行檢查(通過一個GET變量傳遞消息id),然后我們執(zhí)行我們的SQL命令。注意這兒SQL的用法。你需要了解如何使用別名和關(guān)聯(lián)表。
10、當(dāng)你只需要一個對象時,使用單例模式
在PHP中相當(dāng)常見的一種情形時,我們只需要創(chuàng)建一個對象一次,然后在我們的整個程序中使用它。一個很好的例子就是smarty變量,一旦被初始化后就可以在任何地方使用。這種情形的一個很好實現(xiàn)方案就是單例模式。示例代碼如下:
復(fù)制代碼 代碼如下:
function smartyObject()
{
if ($GLOBALS['config']['SmartyObj'] == 0)
{
$smarty = new SmartyGame();
$GLOBALS['config']['SmartyObj'] = $smarty;
}
else
$smarty = $GLOBALS['config']['SmartyObj'];
return $smarty;
}
注意,我們擁有一個全局smarty變量(該示例中它在config.php中被初始化),如果它的值為0,我們將創(chuàng)建一個新smarty對象。否則,它意味著該對象已經(jīng)被創(chuàng)建,我們只需要返回它。
相關(guān)文章
php數(shù)組函數(shù)序列之a(chǎn)rray_unique() - 去除數(shù)組中重復(fù)的元素值
array_unique() 函數(shù)移除數(shù)組中的重復(fù)的值,并返回結(jié)果數(shù)組。 當(dāng)幾個數(shù)組元素的值相等時,只保留第一個元素,其他的元素被刪除。2011-10-10php中print(),print_r(),echo()的區(qū)別詳解
本文介紹了php函數(shù)print(),print_r(),echo()的區(qū)別,這里推薦給大家,需要的朋友可以參考下2014-12-12php數(shù)組函數(shù)序列之sort() 對數(shù)組的元素值進行升序排序
sort() 函數(shù)按升序?qū)o定數(shù)組的值排序。注釋:本函數(shù)為數(shù)組中的單元賦予新的鍵名。原有的鍵名將被刪除2011-11-11Ping服務(wù)的php實現(xiàn)方法,讓網(wǎng)站快速被收錄
這篇博文繼續(xù)說說這個ping服務(wù)的問題,首先歸納和總結(jié)以下資料2012-02-02php根據(jù)id生成10位不重復(fù)數(shù)字跟字母混合字符串
這篇文章主要介紹了php根據(jù)id生成10位不重復(fù)數(shù)字跟字母混合字符串方法,需要的朋友可以參考下2023-05-05php download.php實現(xiàn)代碼 跳轉(zhuǎn)到下載文件(response.redirect)
一直對php不太熟悉,今天需要類型asp的 response.redirect語句,但一直沒有很好的解決方法。下面是問了朋友才知道的。2009-08-08