有些函數(shù)名稱是有多個(gè)單詞組成的。一般有三種單詞組合的習(xí)慣:
直接拼接:getnumberoffiles
用下劃線分開:get_number_of_files
駱駝法則:getNumberOfFiles
大部分語言選擇其中一中。但是PHP都用到了。
例如,你想要把一些特殊字符轉(zhuǎn)換成HTML實(shí)體,你會(huì)使用函數(shù)htmlentities(直接拼接單詞)。如果你要使用相反的功能,你要用到它的小弟html_entity_decode。由于某些特殊的原因,這個(gè)函數(shù)名是由下劃線分隔單詞。怎么能這樣呢?你知道有一個(gè)函數(shù)叫strpad。或者他是str_pad?每次你都要查看一下到底這個(gè)符號是什么或者直接等他出現(xiàn)一個(gè)錯(cuò)誤。函數(shù)是不分大小寫的,所以對于PHP來說rawurldecode和RawUrlDecode之間沒有什么區(qū)別。這也很糟糕,因?yàn)閮蓚€(gè)都使用到了同時(shí)他們看上去還不一樣,混淆了閱讀者。
8、魔法引用的地獄魔法引用(Magicquote)可以保護(hù)PHP腳本免受SQL注入攻擊。這很好。但是出于某些原因,你可以在php.ini中關(guān)閉這個(gè)配置。所以你如果要寫出一個(gè)有彈性的腳本,你總要檢查魔法引用是開啟還是關(guān)閉。這樣一個(gè)“特性”應(yīng)該讓編程更簡單,而事實(shí)上變得更復(fù)雜了。
9、缺少標(biāo)準(zhǔn)框架一個(gè)成長中的網(wǎng)站沒有一個(gè)整體框架,最終會(huì)變成維護(hù)的噩夢。一個(gè)框架可以讓很多工作變得簡單。現(xiàn)在最流行的框架模型時(shí)MVC-模型,在其中表現(xiàn)層、業(yè)務(wù)邏輯和數(shù)據(jù)庫訪問都分離開了。
很多PHP網(wǎng)站不使用MVC-模型。他們甚至沒有一個(gè)框架。甚至現(xiàn)在有一些PHP框架同時(shí)你都可以自己寫一個(gè),關(guān)于PHP的文章和手冊沒有提高框架的一個(gè)字。同時(shí)JSP-開發(fā)人員使用像Struts的框架、ASP開發(fā)人員使用.net,看起來好像這些概念都廣泛被PHP開發(fā)人員所了解。這就說明了PHP實(shí)際上到底是多專業(yè)。
總結(jié)對于非常小的項(xiàng)目,它可以是一個(gè)十分符合人意的編程語言。但是對于較大的和更為復(fù)雜的項(xiàng)目,PHP就顯出他的薄弱了。當(dāng)你不斷地摸索之后,你會(huì)發(fā)現(xiàn)我提到的某些問題的解決方案。所以,當(dāng)解決方案已知之后,為什么不能修正他呢?另外,為什么這些修補(bǔ)不在手冊中提到呢?一個(gè)開源的語言十分流行是一件好事。但不幸得是,它不是一個(gè)偉大的語言。我希望所有的問題能有一天得到解決(也許在PHP6),然后,我們就將擁有一個(gè)開源語言,他既開源,又好用。
到現(xiàn)在,當(dāng)你要啟動(dòng)一個(gè)多于5個(gè)腳本頁面的項(xiàng)目的時(shí)候,你最好考慮C#ASP.NET或者JavaJSP或者也許Python同樣是一個(gè)更好的選擇。(IT專家網(wǎng)論壇)
信息發(fā)布:廣州名易軟件有限公司 http://www.jetlc.com