這些標記告訴預處理器,它們包含代碼,并且應對它們作出處理。與 CGI 非常相似,這些代碼在服務器上運行,并返回一些內容,這些內容表現(xiàn)為發(fā)回給瀏覽器的結果 HTML 頁面的部分外觀。開放源代碼腳本語言 PHP 和 Microsoft 的 ASP.NET 框架中的語言都屬于這種類型;JavaServer Pages (JSP) 和 Perl/Mason 也以這種方式運行。 在本文中,我將重點講述 PHP - Oracle 已選擇合并到其產(chǎn)品中的技術 - 和 ASP.NET。我將概述兩者的各種優(yōu)勢和弱點,并著重討論那些將幫助您決定開發(fā)項目應選擇哪種技術的因素。有很多因素需要考慮,不同的項目可能訴諸于不同的技術。總之,您將看到在價格、速度和效率、安全性、跨平臺支持等方面的逐項比較,以及開放源代碼解決方案的優(yōu)勢。 什么是 ASP.NET? ASP 最新的版本 ASP.NET 并不完全與 ASP 早期的版本后向兼容,因為該軟件進行了完全重寫。早期的 ASP 技術實際上與 PHP 的共同之處比與 ASP.NET 的共同之處多得多,ASP.NET 是用于構建 Web 應用程序的一個完整的框架。這個模型的主要特性之一是選擇編程語言的靈活性。ASP.NET 可以使用腳本語言(如 VBScript、JScript、Perlscript 和 Python)以及編譯語言(如 VB、C#、C、Cobol、Smalltalk 和 Lisp)。新框架使用通用語言運行環(huán)境 (CLR);先將您語言的源代碼編譯成 Microsoft 中間語言代碼,然后 CLR 執(zhí)行這些代碼。 這個框架還提供真正的面向對象編程 (OOP),并支持真正的繼承、多態(tài)和封裝。.NET 類庫根據(jù)特定的任務(例如,使用 XML 或圖像處理)組織成可繼承的類。 除了編程語言和方法之外,數(shù)據(jù)庫訪問也是要著重關心的一個因素。當您用 ASP.NET 編程時,可以用 ODBC 來集成數(shù)據(jù)庫;ODBC 提供了一組一致的調用函數(shù)來訪問您的目標數(shù)據(jù)庫。 優(yōu)勢和弱點 ASP.NET 的優(yōu)勢很明顯在于它簡潔的設計和實施。這是面向對象的編程人員的夢想:語言靈活,并支持復雜的面向對象特性。在這種意義下,它真正能夠與編程人員現(xiàn)有的技能進行互操作。 ASP.NET 的另一個優(yōu)勢是其開發(fā)環(huán)境。例如,開發(fā)人員可以使用 WebMatrix(一個社區(qū)支持的工具)、Visual Studio .NET 或各種 Borland 工具(如 Delphi 和 C++ Builder)。例如,Visual Studio 允許設置斷點、跟蹤代碼段和查看調用堆棧??偠灾?,它是一個復雜的調試環(huán)境。許多其他第三方的 ASP.NET IDE 解決方案也將必然出現(xiàn)。
但您得到了強健性,就將以損失效率為代價。ASP.NET 在內存使用和執(zhí)行時間方面耗費非常大,這大部分歸因于較長的代碼路徑。對基于 Web 的應用程序,這些局限可能是一個嚴重的問題,因為在 Web 上,您的應用程序可能擴展為每秒成千上萬的用戶。內存使用率還可能成為 Web 服務器上的一個問題。 什么是 PHP? PHP 是基于預處理 HTML 頁面模型的一種腳本語言。當 Web 服務器中的 PHP 預處理器發(fā)現(xiàn)像下面這樣的 PHP 語言標記時,將調用 PHP 引擎來執(zhí)行該代碼: ?php some code here ?> 任何使用過命令式編程語言的編程人員都會對 PHP 非常熟悉;您會發(fā)現(xiàn)它與 Perl、C 和 Java 在語法上的相似處。嚴格來講,Java 是一種命令式編程語言,但它也利用了面向對象的結構和概念。PHP 在適宜的時候借鑒了這種結構,但它不是一種純粹的 OOP 語言。 在上面對 ASP.NET 的討論中,我提到了 ODBC 驅動程序,以及在考慮數(shù)據(jù)庫抽象的情況下如何構建應用程序。在 PHP 中,您也可以使用 ODBC 與數(shù)據(jù)庫對話,因此您已經(jīng)有了一系列支持的數(shù)據(jù)庫可供選擇。也有 MySQL、Oracle 和 Postgres 的原生驅動程序。此外,如果要使用 Oracle,則有一個特殊的 OCI8 庫將提供對 Oracle 更多訪問功能,從而允許您使用諸如 LOB、BLOB、CLOB 和 BFILE 之類的特性。 這時您可能會問"為什么與數(shù)據(jù)庫相關的資料庫被稱為 PHP 的特性?"數(shù)據(jù)庫抽象或獨立性是您在設法構建使用多種數(shù)據(jù)庫或需要在數(shù)據(jù)庫間移植(例如,從開發(fā)到投產(chǎn)時的移植)的應用程序時所要考慮的一個因素。而這些確實是應該關心和考慮的。 但正如 Tom Kyte 在他的新書 - Effective Oracle by Design (Oracle 出版社) - 中指出的那樣,數(shù)據(jù)庫相關性將成為您真正的目標,因為這將使您在該技術中的投資最大化。如果您對 Oracle 進行一般的訪問 - 無論通過 ODBC 或 Perl 的 DBI 庫,那么您將無法使用其他數(shù)據(jù)庫所不具有的特性。此外,優(yōu)化查詢在各個數(shù)據(jù)庫中各不相同。 Zend Technologies 是一家商業(yè)軟件公司,它對 PHP 作出了重大貢獻。它創(chuàng)建了一個稱為 Zend Studio 的商業(yè)開發(fā)環(huán)境,這個環(huán)境包含了一個復雜的調試器、一個監(jiān)測器和其他特性。該公司還構建了免費的 Zend Optimizer,它與 Zend Encoder 結合使用來編譯 PHP 代碼,以提升性能。還有其他商業(yè)產(chǎn)品,如 Zend Performance Suite,它可以緩存預編譯的 PHP 頁面,從而進一步顯著提升總體性能。
優(yōu)勢和弱點 到測試版 4 為止,PHP 5 仍然有一些缺點,包括缺少異常和基于事件的錯誤處理例程 - 它們能夠中斷正常的程序流,并將代碼跳轉到一個特殊的錯誤處理部分。Java 也提供了用于錯誤處理的異常,而 C++ 通過 try、catch 和 throw 語法提供異常處理。當然,您仍然可以在 PHP 中管理錯誤,但其結構不是標準化的,因而使得編程人員必須使用自己的工具來決定執(zhí)行錯誤處理的方式,這將導致更低的一致性并往往導致推倒重來。 另一個弱點是 PHP 的函數(shù)名是不區(qū)分大小寫的。雖然這不是一個嚴重的缺點,但有些程序員可能會覺得這一特性很討厭。 不過,我的確對 PHP 的對象模型心存疑慮。PHP 不是專門設計為一種面向對象的語言。這些特性中的一部分是后來添加的 - 盡管注意了保持與 PHP 3 的后向兼容性,因此兩種模型的特性都留有一些。實際上,在 PHP 5 中這些弱點中的許多都得到了解決。請留心關注。 PHP 在一些領域中缺少什么,它就會在擅長的領域中迅速地彌補什么。價格合理,因此您不需要擔心許可問題。它也是開放源代碼的,因此整個社區(qū)將密切關注開發(fā)過程:發(fā)現(xiàn)錯誤并將其修復。如果有一個特性您不喜歡,那么您可以修改代碼。此外,PHP 可與 Apache 自然結合:它可以作為一個模塊編譯,或直接編譯成 Apache 二進制文件。 但在 Apache 上運行意味著,利用 PHP,您能夠利用您已經(jīng)在任意服務器投資,這是因為 Apache 能夠運行在 Windows、Linux、Solaris 和各種其他 Unix 平臺上。此外,使用擁有 Apache 的跟蹤記錄的 web 服務器意味著安全性能夠保持在最高的優(yōu)先級上。最后,PHP 擁有更小的代碼路徑,這意味著更少的分析和執(zhí)行 PHP 頁面服務器端代碼,這將帶來更高效的內存和使用率以及更快的運行。 在 PHP 5 中新增了哪些特性? PHP 5 的第 4 個測試版在 2003 年 12 月底推出,更改日志清楚地顯示已發(fā)現(xiàn)許多錯誤并已將其消除。雖然它仍在進行測試,但它的所有新特性和進步都確實值得關注。 PHP 5 的主要新成就在于它的異常處理和一個新對象,這個新對象引入的特性賦予了 PHP 真正的 OOP。異常處理無疑是 PHP 4 中最顯著的缺憾之一,而 PHP 5 對異常處理的引入無疑是一個成熟的標志。異常處理意味著您在您的軟件中擁有了根據(jù)語言定義的和標準化的錯誤處理方法。只需使用 try、catch 和 throw 方法,您的 PHP 代碼就變得更加強健和簡潔。 ?phpclass blue {function openFile ($inFile) {if (file_exists ($inFile)) {# code to open the file here} else {throw new Exception ("Cannot open file:$inFile"); } }} $blueObj = new blue ();try {$blueObj->openFile ('/home/shull/file.txt');} catch (Exception $myException) {echo $myException->getMessage (); # rest of exception handling code here}# rest of blue methods here?> 新的對象模型為用 PHP 編寫的程序帶來許多積極的影響。在 PHP 4 中,當把將一個對象傳遞給函數(shù)或方法時,是通過值來傳遞的 - 除非您另行顯式告知 PHP。這個過程意味著必須復制對象的一個副本(內存中的所有數(shù)據(jù)結構)。這個步驟使用內存,使得訪問變慢和擁塞。而在 PHP 5 中,通常通過引用傳遞對象。 PHP 5 中新的面向對象的特性(包括構造器和析構器)值得關注。與 C++ 和 Java 相同,它們提供了一種標準方法,即通過一個構造器方法來創(chuàng)建對象、分配內存和執(zhí)行任何必要的設置,并通過一個析構器方法來執(zhí)行清理。 PHP 5 還引入了對類中方法和變量的更精細控制。在 PHP 4,一切都是公有的:您可以從類外或在繼承類中訪問您類中的變量。在 PHP 5 中,您仍然可以使變量或方法為公有,但您也可以使它們?yōu)樗接?,以使得只能在類本身中使用它們。還可以將它們保護起來,也就是說,可以在類內或在子類中查看方法和變量。 此外,PHP 5 引進了類型提示或更好的類型檢查。當您將一個對象傳遞給一個例程時,PHP 能夠檢查它是否是正確的類型,并在檢查失敗時產(chǎn)生類型不匹配錯誤。 由于還有其他特性(如靜態(tài)方法和變量以及抽象類),因此請務必查看文檔,以獲取詳細信息。 安全性比較 ASP.NET 官方要求您使用 IIS。不幸的是,IIS 易受攻擊的歷史由來已久,這使得許多管理員不愿意部署它來處理 Web 站點。這些弱點是因為 Microsoft 的缺陷或是因為 IIS 是黑客們攻擊的目標無關緊要:這些系統(tǒng)有被黑或被攻擊的歷史。PHP 也運行在 Apache 上,Apache 快速并且是開放源代碼的,并擁有很好的安全性記錄。此外,正如我提到過的,Apache 可以在許多平臺上運行。 如果您在考慮 ASP.NET,但您想用 Apache 作為 Internet 門戶,那么很幸運您可以有一些選擇。首先,您可以使用 Apache 將請求轉發(fā)給在另一臺計算機上內部運行的 IIS。然后 Apache 處理靜態(tài)內容,并將 aspx 內容傳送給 IIS 服務器(不暴露給 Internet)。 不過,如果您想利用 Apache 承載 ASP.NET,那么提供了一些選項,這些選項 Microsoft 可能支持也可能不支持。作為最后一種選擇,有 Ximian 的 Project Mono,它致力于構建一個開放源代碼模塊。請瀏覽 http://www.go-mono.com/,以獲取更多信息。 數(shù)據(jù)庫編碼示例 您在選用 PHP 或 ASP.NET 時首先要考慮因素之一就是與數(shù)據(jù)庫的連接。不過,利用 ASP.NET 更復雜,因為您可以從許多備選語言中選擇任意一種語言。當然,這些代碼示例將必須嵌入到 HTML 頁面、實例化的類等之中。不過,以下信息將使您對二者的編碼風格有所了解。 PHP 5 與 Oracle 連接 下面是一個 PHP 5 類,它提供了一個 Oracle 連接和斷開例程,用以演示利用 PHP 5(也可以使用其他驅動程序(如 ODBC 驅動程序)和通用的數(shù)據(jù)庫接口)與 Oracle 連接的一種方式: class oracle_object { protected $theDB; protected $user; protected $pass; protected $db; function __construct($u, $p, $d) { $this->user = $u; $this->pass = $p; $this->db = $d; } function db_open () { $theDB = @OCILogon($this->user, $this->pass, $this->db); db_check_errors($php_errormsg); } function db_close() { @OCILogoff($theDB); db_check_errors($php_errormsg); } function __destruct () { print ("so long..."); } } ASP.NET 與 Oracle 連接 如果您希望利用 VB.NET(Visual Basic 是 Microsoft 的默認 .NET 編程語言)與 Oracle 連接,那么請看一下這個來自 MSDN 的示例: Imports System Imports System.Data Imports System.Data.OracleClient Imports Microsoft.VisualBasic Class Sample Public Shared Sub Main() Dim oraConn As OracleConnection = New OracleConnection ("Data Source=MyOracleServer;Integrated Security=yes;") Dim oraCMD As OracleCommand = New OracleCommand ("SELECT CUSTOMER_ID, NAME FROM DEMO.CUSTOMER", oraConn) oraConn.Open() Dim myReader As OracleDataReader = oraCMD.ExecuteReader() Do While (myReader.Read()) Console.WriteLine(vbTab "{0}" vbTab "{1}", myReader.GetInt32(0), myReader.GetString(1)) Loop myReader.Close() oraConn.Close() End Sub End Class
巨人網(wǎng)絡通訊聲明:本文標題《php asp.net 比較 [推薦]》,本文關鍵詞 php,asp.net,比較,推薦,php,;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。