[PHP]:
PHP 是 PHP: Hypertext Preprocessor (超文本預(yù)處理器) 的縮寫,它是一種服務(wù)器端的 HTML 腳本編程語言,是一種簡單的、面向?qū)ο?/strong>的、解釋型的、健壯的、安全的、性能非常之高的、獨立于架構(gòu)的、可移植的、動態(tài)的腳本語言。
PHP 是能讓你生成動態(tài)網(wǎng)頁的工具之一。PHP 是完全免費的,不用花錢,你可以從PHP 官方站點(http://www.php.net)自由下載。PHP 遵守GNU 公共許可(GPL),在這一許可下誕生了許多流行的軟件諸如Linux和Emacs。你可以不受限制的獲得源碼,甚至可以從中加進你自己需要的特色。PHP 在大多數(shù)Unix 平臺,GUN/Linux和微軟Windows平臺上均可以運行。怎樣在Windows環(huán)境的PC 機器或Unix機器上安裝PHP 的資料可以在PHP 官方站點上找到,也可以查閱網(wǎng)頁陶吧的“PHP 安裝全攻備”專題文章。安裝過程很簡單。
如果你的機器解決了2000問題,那么PHP 也一樣沒有千年蟲問題!
歷史
三年前,Rasmus Lerdorf為了創(chuàng)建他的在線簡歷而創(chuàng)造了"個人主頁工具"(Personal Home Page Tools)。這是一種非常簡單的語言。其后越來越多的人們注意到了這種語言并對其擴展提出了各種建議。在許多人的無私奉獻下以及這種語言本身的源代碼自由性質(zhì),它演變成為一種特點豐富的語言,而且現(xiàn)在還在成長中。
PHP 雖然很容易學(xué)習(xí),但是速度上比mod_perl(植入web服務(wù)器的perl模塊)慢?,F(xiàn)在有了可以與mod_perl 速度想媲美的被稱作Zend 的新引擎,而PHP4 就可以充分利用這個引擎?,F(xiàn)在,PHP4 正式版已經(jīng)發(fā)布,大家可以到php 的官方站點上去下載。Andy Gutmans 和Zeev Suraki 是Zend 的主要作者??梢匀end 站點(http://www.zend.com)了解更多。
PHP 的應(yīng)用在個人性質(zhì)的web工程中增長顯著。根據(jù)Netcraft在1999 年10月的報告,有931122個域和321128 個IP 地址利用PHP 技術(shù)。
應(yīng)用PHP 有許多好處。當(dāng)然已知的不利之處在于PHP 由于是開放源碼項目,沒有什么商業(yè)支持,并且由此而帶來的執(zhí)行速度緩慢(直到PHP4 之前)。但是PHP 的郵件列表很是有用而且除非你正在運行像Yahoo!或者Amazon.com 這樣的極受歡迎的站點,你不會感覺出PHP 的速度與其他的有什么不同。最起碼我就沒有感覺出來!好了,讓我們來看看PHP 有那些優(yōu)點:
學(xué)習(xí)過程
我個人更喜歡PHP 的非常簡單的學(xué)習(xí)過程。與Java和Perl 不同,你不必把頭埋進100 多頁的文檔中努力學(xué)習(xí)才可以寫出一個象樣的程序。只要了解一些基本的語法和語言特色,你就可以開始你的PHP 編碼之旅了。之后你在編碼過程中如果遇到了什么麻煩,還可以再去翻閱相關(guān)文檔。
PHP 的語法類似于C,Perl,ASP 或者JSP。對于那些對上述之一的語言較熟悉的人來說,PHP 太簡單了。相反的,如果你對PHP 了解較多,那么你對于其他幾種語言的學(xué)習(xí)都很簡單了。
你只需要30分鐘就可以將PHP 的核心語言特點全部掌握,你可能已經(jīng)非常了解HTML,甚至你已經(jīng)知道怎樣用編輯設(shè)計軟件或者手工來制作好看的WEB 站點。由于PHP 代碼能夠無障礙的添加進你的站點,在你設(shè)計和維護站點的同時,你可以很輕松的加入PHP 使得你的站點更加具有動態(tài)特性。
數(shù)據(jù)庫連接
PHP 可以編譯成具有與許多數(shù)據(jù)庫相連接的函數(shù)。PHP 與MySQL是現(xiàn)在絕佳的組合。你還可以自己編寫外圍的函數(shù)取間接存取數(shù)據(jù)庫。通過這樣的途徑當(dāng)你更換使用的數(shù)據(jù)庫時,可以輕松的更改編碼以適應(yīng)這樣的變化。PHPLIB就是最常用的可以提供一般事務(wù)需要的一系列基庫。
可擴展性
就像前面說的那樣,PHP 已經(jīng)進入了一個高速發(fā)展的時期。對于一個非程序員來說為PHP 擴展附加功能可能會比較難,但是對于一個PHP 程序員來說并不困難。
面向?qū)ο缶幊?BR>PHP 提供了類和對象?;趙eb的編程工作非常需要面向?qū)ο缶幊棠芰ΑHP支持構(gòu)造器、提取類等。
可伸縮性
傳統(tǒng)上網(wǎng)頁的交互作用是通過CGI來實現(xiàn)的。CGI程序的伸縮性不很理想,因為它為每一個正在運行的CGI程序開一個獨立進程。解決方法就是將經(jīng)常用來編寫CGI程序的語言的解釋器編譯進你的web服務(wù)器(比如mod_perl,JSP)。PHP 就可以以這種方式安裝,雖然很少有人愿意這樣以CGI方式安裝它。內(nèi)嵌的PHP 可以具有更高的可伸縮性。
更多特點
PHP 的開發(fā)者們?yōu)榱烁m合web編程,開發(fā)了許多外圍的流行基庫,這些庫包含了更易用的層。你可以利用PHP 連接包括Oracle,MS-Access,Mysql在內(nèi)的大部分?jǐn)?shù)據(jù)庫。你可以在蒼蠅上畫圖,編寫程序下載或者顯示e-mail。你甚至可以完成網(wǎng)絡(luò)相關(guān)的功能。最好的是,你可以選擇你的PHP 安裝版本需要哪些功能。引用Nissan 的Xterra 的話來說就是PHP 可以做到你想讓它做到的一切而且無所不能!
[MySQL]:
MySQL是一個廣受Linux社區(qū)人們喜愛的半商業(yè)的數(shù)據(jù)庫。 MySQL是可運行在大多數(shù)的Linux平臺(i386,Sparc,etc),以及少許非Linux甚至非Unix平臺。
1、許可費用
MySQL的普及很大程度上源于它的寬松,除了略顯不尋常的許可費用。MySQL的價格隨平臺和安裝方式變化。MySQL的Windows版本(NT和9X)在任何情況下都不免費,而任何Unix變種(包括Linux)的MySQL如果由用戶自己或系統(tǒng)管理員而不是第三方安裝則是免費的,第三方案莊則必須付許可費。
2、價格
平臺安裝方式價格
Windows NT,9X 任何200美元
Unix或Linux 自行安裝免費
Unix或Linux 第三方安裝200美元
需要一個應(yīng)用組件200美元
可以得到多種支持合同,內(nèi)容太多不再羅列,最新報價可咨詢MySQL站點。
3、安裝
可以在MySQL站點上獲得大多數(shù)主要的軟件包格式(RPM、DBE、TGZ),客戶端庫和各種語言“包裝”(Wrapper)可以分開的RPM格式獲得。RPM格式的安裝沒有多大麻煩,并且無需初始配置。在rc3.d(以RedHat RPM為例)生成一個初始腳本,故MySQL守護進程在多用戶模式下重啟時被啟動運行。MySQL的守護進程(mysqld)消耗很少的內(nèi)存(在運行RedHat 5.1的奔騰133上,每個守護進程使用500K內(nèi)存和另外4M共享內(nèi)存的開銷)并在只有在執(zhí)行真正的查詢時才裝載到處理器上,這意味著對小型數(shù)據(jù)庫來說,MySQL可以相當(dāng)輕松地使用而不會對其他系統(tǒng)功能有太大的影響。
4、數(shù)據(jù)類型
字段支持大量數(shù)據(jù)類型是件好事。通常的整數(shù)、浮點數(shù)、字符串和數(shù)字均以多種長度表示,并支持變長的BLOB(Binary Large OBject)類型。對整數(shù)字段由自動增量選項,日期時間字段也能很好的表示。
MySQL與大多數(shù)其他數(shù)據(jù)庫系統(tǒng)不同的是提供兩個相對不常用的字段類型:ENUM和SET。ENUM是一個枚舉類型,非常類適于Pascal語言的枚舉類型,它允許程序員看到類似于'red、'green'、'blue'的字段值,而MySQL只將這些值存儲為一個字節(jié)。SET也是從Pascal借用的,它也是一個枚舉類型,但一個單獨字段一次可存儲多個值,這種存儲多個枚舉值的能力也許不會給你一些印象(并可能威脅第三范式定義),但正確使用SET和CONTAINS關(guān)鍵字可以省去很多表連接,能獲得很好的性能提高。
5、SQL兼容性
MySQL包含一些與SQL標(biāo)準(zhǔn)不同的轉(zhuǎn)變,他們的大多數(shù)被設(shè)計成是對SQL語言腳本語言的不足的一種補償。然而,另一些擴展確實使 MySQL與眾不同,例如,LINK子句搜索是自動地忽略大小寫的。MySQL 也允許用戶自定義的SQL函數(shù),換句話說,一個程序員可以編寫一個函數(shù)然后集成到MySQL中,并且其表現(xiàn)的與任何基本函數(shù)如SUM()或AVG ()沒有什么不同。函數(shù)必須被編譯道一個共享庫文件中(.so文件),然后用一個LOAD FUNCTION
命令裝載。
它也缺乏一些常用的SQL功能,沒有子選擇(在查詢中的查詢)。視圖(View)也沒了。當(dāng)然大多數(shù)子查詢可以用簡單的連接(join)子句重寫,但有時用兩個嵌套的查詢思考問題比一個大連接容易。同樣,視圖僅僅為程序員隱蔽where子句,但這正是程序員們期望的另一種便利。
6、存儲過程和觸發(fā)器
MySQL沒有一種存儲過程(Stored Procedure)語言,這是對習(xí)慣于企業(yè)級數(shù)據(jù)庫的程序員的最大限制。多語句SQL命令必須通過客戶方代碼來協(xié)調(diào),這種情形是借助于相當(dāng)健全的查詢語言和賦予客戶端鎖定和解鎖表的能力,這樣才允許的多語句運行。
7、參考完整性(Referential Integrity-RI)
MySQL的主要的缺陷之一是缺乏標(biāo)準(zhǔn)的RI機制;然而,MySQL的創(chuàng)造者也不是對其用戶的愿望置若罔聞,并且提供了一些解決辦法。其中之一是支持唯一索引。Rule限制的缺乏(在給釘字段域上的一種固定的范圍限制)通過大量的數(shù)據(jù)類型來補償。不簡單地提供檢查約束(一個字段相對于同一行的另一個字段的之值的限制)、外部關(guān)鍵字和經(jīng)常與RI相關(guān)的“級聯(lián)刪除”功能。有趣的是,當(dāng)不支持這些功能時,SQL分析器容忍這些語句的句法。這樣做目的是易于移植數(shù)據(jù)庫到MySQL中。這是一個很好的嘗試,并且它確實未來支持該功能留下方便之門;然而,那些沒有仔細(xì)閱讀文檔的的人可能誤以為這些功能實際上是存在的。
8、安全性
自始至終我對MySQL最大的抱怨是其安全系統(tǒng),它唯一的缺點是復(fù)雜而非標(biāo)準(zhǔn),另外只有到調(diào)用mysqladmin來重讀用戶權(quán)限時才發(fā)生改變。通常的SQL GRANT/REVOKE 語句到最近的版本才被支持,但是至少他們現(xiàn)在有了。 MySQL的編寫者廣泛地記載了其特定的安全性系統(tǒng),但是它確實需要一條可能是別無它法的學(xué)習(xí)過程。
[Apache]:
Apache是目前互聯(lián)網(wǎng)上最流行的Web服務(wù)器,它可以運行在幾乎所有廣泛使用的計算機平臺上。最早版本是于1995年12月1日發(fā)布的。最初的Apache版本是由美國伊利諾斯大學(xué)香檳分校(University of Illinios, Urbana-Champaign.)國家超級計算應(yīng)用中心(NCSA)的Rob McCool先生開發(fā)的the Public Domain HTTPS Daemon程序發(fā)展而來。Apache源于NCSAhttpd服務(wù)器,經(jīng)過多次修改,成為世界上最流行的Web服務(wù)器軟件之一。Apache取自“a patchy server”的讀音,意思是充滿補丁的服務(wù)器,因為它是自由軟件,所以不斷有人來為它開發(fā)新的功能、新的特性、修改原來的缺陷。Apache的特點是簡單、速度快、性能穩(wěn)定,并可做代理服務(wù)器來使用。
[Zend Studio]:
Zend Studio被證實的最優(yōu)秀的PHP開發(fā)環(huán)境,是專業(yè)開發(fā)人員在使用PHP整個開發(fā)周期中唯一的集成開發(fā)環(huán)境 (IDE),它包括了PHP所有必須的開發(fā)部件。通過一整套編輯、調(diào)試、分析、優(yōu)化和數(shù)據(jù)庫工具,Zend Studio 加速開發(fā)周期,并簡化復(fù)雜的應(yīng)用方案。
Zend Studio產(chǎn)品特征
Zend Studio 設(shè)計時考慮了商務(wù)應(yīng)用開發(fā)的需要,是開發(fā)者利用PHP創(chuàng)造強有力數(shù)據(jù)庫應(yīng)用軟件的完美開發(fā)環(huán)境。Zend Studio 具有專業(yè)和企業(yè)開發(fā)者開發(fā)、配置、調(diào)試和管理關(guān)鍵商務(wù)PHP應(yīng)用的易使用性、可伸縮性、可靠性和擴展性。
PHP最強有力的開發(fā)環(huán)境
提高生產(chǎn)力:通過完全的PHP5支持、編碼分析器、編碼組合功能、語法檢索、項目管理器、編碼編輯器、繪圖調(diào)試器(向?qū)В?BR>超強智能編碼:具備新的和更優(yōu)秀的分析和優(yōu)化工具像PHP編碼檢測器,。
PHP的標(biāo)準(zhǔn)記錄工具--PHP文檔記錄器:非常容易記錄PHP代碼、程序應(yīng)用和方案。
FTP和SFTP組合簡化配置,使開發(fā)者安全地從遠程服務(wù)器靈活的上載和下載項目文件。
高水平的商務(wù)應(yīng)用開發(fā)
直接鏈接最廣泛使用的專業(yè)數(shù)據(jù)庫,像IBM DB2/Cloudscape/Derby、MySQL、Oracle、Microsoft SQL Server, PostgreSQL 和 SQLite。
通過使用帶 SQL92 和 語法檢索支持的Zend SQL Query Editor,到被鏈接服務(wù)器上進行寫和執(zhí)行程序的訪問。
用 Zend SQL Explorer 觀看數(shù)據(jù)庫結(jié)構(gòu)和管理內(nèi)容。
PHP完整的調(diào)試環(huán)境
先進的調(diào)試特征優(yōu)勢,包括:Conditional Breakpoints, Stack Trace View, Advanced Watches, Variables and Output Buffer
利用最強大的PHP調(diào)試器在本地或遠程調(diào)試本地的環(huán)境。
對于本地調(diào)試或者是基于互聯(lián)網(wǎng)的遠程調(diào)試都能夠確保安全連接。
用“一次點擊瀏覽器調(diào)試”從瀏覽器直接調(diào)試和分析編碼。
強有力的團隊開發(fā)和管理工具
從 Zend Studio 內(nèi)直接應(yīng)用 CVS,通過有效地管理源代碼 ,容易進行團隊的開發(fā)與合作。
利用綜合性能編輯器,監(jiān)視訪問功能,優(yōu)化應(yīng)用程序的總體性能。
Zend Studio 與 Zend Platform 結(jié)合使用時,可以實時獲得代碼和腳本性能的反饋。
Zend Studio 為流行的 SQL 數(shù)據(jù)庫包括 MySQL、Oracle、IBM DB2 和Cloudscape、微軟SQL服務(wù)器、SQLite 和 Postgre SQL提供查詢、編輯和執(zhí)行能力。
更多相關(guān)信息可以在Zend官方網(wǎng)站查詢:www.zend.com,或Zend中國技術(shù)支持中心www.phpchina.com找到。
最新的Zend Studio 5.5下載地址:http://downloads.phpchina.com/zend/studio/5.5.0/
相關(guān)問題資料查詢下載:http://www.phpchina.com/bbs/forum-125-1.html。
如對本文有疑問,請?zhí)峤坏浇涣髡搲瑥V大熱心網(wǎng)友會為你解答?。?點擊進入論壇