明輝手游網(wǎng)中心:是一個免費提供流行視頻軟件教程、在線學(xué)習(xí)分享的學(xué)習(xí)平臺!

創(chuàng)建靈巧結(jié)構(gòu)的PHP程序

[摘要]很早就想寫這篇文章了,但一直沒有時間完成它。不是說我來告訴大家如何做,我更希望本文只是做為一個引子,與大家來討論關(guān)于如何建立一個有效地、靈活的網(wǎng)絡(luò)應(yīng)用程序。 經(jīng)過了2-3年的網(wǎng)絡(luò)應(yīng)用程序開發(fā)工作,我的開發(fā)經(jīng)驗變得更加生動了,回過頭來看我以前為Geocrawler寫的代碼,簡直不敢相信這是我的。由于...

很早就想寫這篇文章了,但一直沒有時間完成它。不是說我來告訴大家如何做,我更希望本文只是做為一個引子,與大家來討論關(guān)于如何建立一個有效地、靈活的網(wǎng)絡(luò)應(yīng)用程序。

經(jīng)過了2-3年的網(wǎng)絡(luò)應(yīng)用程序開發(fā)工作,我的開發(fā)經(jīng)驗變得更加生動了,回過頭來看我以前為Geocrawler寫的代碼,簡直不敢相信這是我的。由于GPL的原因,在PHPBuilder中的源碼也是良莠不齊的。

最近我做為一個有經(jīng)驗的PHP開發(fā)者,一直在幫著寫SourceForge,我想這顯示出了最終結(jié)果的一個范圍。好的代碼應(yīng)被分成了多個部分,合適的庫及函數(shù)調(diào)用,清楚的數(shù)據(jù)庫結(jié)構(gòu),站點的每一個部分與其它部分都是相對獨立的。

但是,這仍不是最好的。如果我可以重做,我將更多的關(guān)注于HTML層與數(shù)據(jù)層的分離,通過對象及清楚的函數(shù)庫實現(xiàn)這一點。

優(yōu)美的圖形

我知道經(jīng)理們喜歡用優(yōu)美的圖形及圖表來描述它們,這將給我們留下最好的印象。用這種隱藏在一個結(jié)構(gòu)后的想法,你可以把你的邏輯與外觀分離,這意味著任何一個復(fù)雜的程序都可以用"API/Data Access Layer"來表述。

與其你把安全檢測、更新的句子等放在HTML層中,不如把它們整體地放在你的API層里。而這個HTML層只含有簡單的函數(shù)調(diào)用和返回的數(shù)組、對象或自定的其它什么,以及一些數(shù)據(jù)庫的檢索結(jié)果的集合等。

如果你這樣做了,頂層將是非常的瘦小,你可以方便地創(chuàng)建及維護(hù)它。

如下的例子中,這個HTML接口中只有一些API層中的函數(shù)的直接調(diào)用,一些HTML工具庫(它能生成一個彈出框等等),和一些從數(shù)據(jù)庫抽象層中調(diào)用的數(shù)據(jù)庫操作方法(你不需要綁定某一個特別的數(shù)據(jù)庫)。基礎(chǔ)

靈活的PHP程序結(jié)構(gòu)最基本的方面有以下幾點:

數(shù)據(jù)庫無關(guān)性
界面無關(guān)性
可移植性
面向?qū)ο蠡蛑辽賾?yīng)由函數(shù)庫組成

還有其它的?
當(dāng)然還有一些其它的東西,但我認(rèn)為那都是太大了,或許你自己能指出它們。


讓我們詳細(xì)地談?wù)勊鼈兠恳粭l吧。

1、數(shù)據(jù)庫無關(guān)性

你從不知道你的站點將會在哪里運行,當(dāng)然在你創(chuàng)建它時,你希望它變和得很大并且有很高的流量。所以你不想把你自己約束在 MS Access 上面或者其它什么輕便的數(shù)據(jù)庫系統(tǒng)。雖然你不能立刻地插入各種不同的數(shù)據(jù)庫系統(tǒng),但是你有可能很方便地在它們中間切換。你有一些不同的選擇可以把你的數(shù)據(jù)庫調(diào)用抽象出來。在PHP中一個奇特的方法是你不得不為每個不同的數(shù)據(jù)庫系統(tǒng)寫出不同的代碼,因為在PHP中對每一種不同的數(shù)據(jù)庫的訪問函數(shù)是不同的。為了避開這點,你可以使用一個抽象地數(shù)據(jù)庫訪問層,就象PHPLib、下一個版本的PEAR、及我們在SourceForge中描述的那樣。

2、界面無關(guān)性

一個應(yīng)用程序是它的技術(shù)更重要還是它所運行的站點更重要?我們并不能真正地知道。我從來不相信這一點--HTML是一個標(biāo)準(zhǔn)。特別是對于一個網(wǎng)絡(luò)應(yīng)用程序而言,界面發(fā)生了改動,意味著我們不得不總是重寫。但是如果你的應(yīng)用程序是很大很復(fù)雜的,你就要為你的數(shù)據(jù)庫建立一些其它的接口了,只要你不想在你的站點程序中到處copy&paste你的訪問檢查等代碼。這也意味著,如果你正確地設(shè)計了你的應(yīng)用程序,你可以很容易地改寫你的站點讓它適應(yīng)WAP,只要簡單地寫一個小的WAP界面,并讓它調(diào)用你的數(shù)據(jù)庫訪問對象而已。但若你沒有很好地設(shè)計你的程序,你把你的HTML版改成WAP版是一個復(fù)雜的工程。

我把這個想法也帶入了SourceForge中,我們有一個巨大的用戶群,為我們發(fā)送/接收bugs、任務(wù)等。首先,我們指出所有的這些將通過我們的web頁面接口,然后,由于Eric Raymond 和其他人給的壓力,我們決定用XML來做數(shù)據(jù)庫的外部接口。

幸運的是我們曾在四月已把程序的核心邏輯代碼與它的界面分離了。我將試著表達(dá)我們是如何做的,希望對你的工作有所幫助。

這個SourceForge的bugs跟蹤器和其它的一些工具被分成兩個庫-這個HTML庫和數(shù)據(jù)訪問庫。這個數(shù)據(jù)訪問庫檢查輸入的值的正確性,處理安全校驗,并且當(dāng)成功/失敗時返回TRUE 或 FALSE。

由于簡化的原因,這個例子并沒有基于一個完善的對象模式,那樣我還要解釋這個基類和它的一些衍生類等等,我想這個例子將給你一個最普通的想法。HTML 庫的例子

//connect to database
require ("database.php");

//common utils like header/footer HTML
require ("html.php");

//data access library
require ("bug_data.php");

echo site_header("Page Title");

echo " Updating A Bug
 ";

if (bug_data_update($field1,$field2,$field3)) {

echo " Update Failed!";

} else {

echo " Updated Bug Successfully";
//echo the global error string
echo $feedback;
}

echo site_footer();

?>


Data 訪問庫的例子

3、可移植性

毫無疑問,你不想讓你的代碼只能用于一個固定的站點,將來我們可能改變色彩的選擇、元素的名稱、字體或其它一些什么,這樣應(yīng)設(shè)置一個config文件,它被多個頁面所包含。更好的觀點是你的站點被模塊化,你不需要copy&paste任何一個HTML文件,我傾向于把這些放入一個函數(shù),在任何需要的地方調(diào)用它們。

同樣的方法可用于數(shù)據(jù)庫的密碼、數(shù)據(jù)庫連接字串等,這些可以放入一個數(shù)據(jù)庫處理的抽象層中。


4、面向?qū)ο?函數(shù)化

我們不是用COBOL開發(fā),所以這意味著我們可以把進(jìn)程分成多個函數(shù)的調(diào)用。每個調(diào)用都是一個自動的行為,有時僅僅是調(diào)用一小段其它的函數(shù)并返回這個結(jié)果。

一個好的例子是在每一個頁面校驗用戶是否登錄,你可以用cookie或查詢數(shù)據(jù)庫來完成這個功能,但一旦你想改變你的驗證系統(tǒng),你不得不改動每一個頁面,其實你應(yīng)該可以通過改動函數(shù)庫里一個普通的函數(shù)就完成這個變動的。任何時候,你寫一段代碼,如果它將會被用于多于一個地方,你就要考慮把它放入一個庫里了。

其它還有什么?

顯然還有很多我沒有談到的事,告訴我你的想法,我將在下一篇文章中來討論它們。特別地是,如果你寫了一個大型的、復(fù)雜的應(yīng)用程序,我想聽聽你是如何規(guī)劃它的及你重做時不什么不同的想法。