溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

有哪些需要在PHP中避免的問(wèn)題

發(fā)布時(shí)間:2020-07-16 10:04:28 來(lái)源:億速云 閱讀:116 作者:Leah 欄目:編程語(yǔ)言

這期內(nèi)容當(dāng)中小編將會(huì)給大家?guī)?lái)有關(guān)有哪些需要在PHP中避免的問(wèn)題,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

1. 不要使用 mysql_ 類函數(shù)

終于,你不用再看到建議不要使用 mysql_ 函數(shù)的提示了。因?yàn)?PHP 7 從核心上完全移除了它們,這意味著請(qǐng)你移步至更好的 mysqli_ 類函數(shù),或者更靈活的 PDO 層。

2. 不要寫無(wú)用的代碼

這看上去是個(gè)無(wú)腦建議,但是隨著 PHP7 速度的提升掩蓋了一些問(wèn)題使它顯得日趨重要。不要僅僅因切到 PHP7 讓網(wǎng)站速度變得快點(diǎn),你就沾沾自喜了。

想理解速度的重要性和如何做的更好,去看看我們這篇文章 初學(xué)者加速優(yōu)化指南。

作為開(kāi)發(fā)者,應(yīng)該確保按需加載腳本,可能時(shí)再組合,編寫高效的數(shù)據(jù)庫(kù)查詢語(yǔ)句,如果可能的話 使用緩存 等等。

3. 不要在文件末尾使用 PHP 閉合標(biāo)簽

如果你隨便看看,就會(huì)發(fā)現(xiàn)大部分 WordPress 核心代碼文件結(jié)尾都省略了 PHP 閉合標(biāo)簽。事實(shí)上,Zend 框架尤為明顯地 禁止了閉合標(biāo)簽。它并非 PHP 所必須,在文件結(jié)尾處省略它,可確保結(jié)尾無(wú)額外空白。

4. 如非必須不要引用傳參

我個(gè)人非常不喜歡引用傳參。我當(dāng)然知道在某些場(chǎng)合下它很有用,但是多數(shù)場(chǎng)合下,它會(huì)使得代碼難以理解,難以遵循,難以預(yù)測(cè)結(jié)果。

人們認(rèn)為引用可以使它們的代碼更快,不過(guò)正如 可敬的 PHP 程序員 的這篇文章所指出的,事實(shí)并非如此。

PHP 內(nèi)置的 shuffle() 或者 sort() 函數(shù),就是糟糕的引用傳參案例。 它修改了原數(shù)組而不是返回一個(gè)打亂的或者排好序的數(shù)組,這是完全違背了我們意愿的。

5. 不要在循環(huán)里使用查詢

在循環(huán)中使用數(shù)據(jù)庫(kù)查詢時(shí)最糟糕的。他會(huì)給系統(tǒng)帶來(lái)不必要的壓力,并且很有可能,你可以在循環(huán)外使用查詢而更快的得到相同的結(jié)果。當(dāng)我碰到必須這樣用的場(chǎng)景時(shí),我通常會(huì)通過(guò)分成兩個(gè)查詢來(lái)構(gòu)造一個(gè)數(shù)組的方式來(lái)解決。然后循環(huán)數(shù)組而無(wú)需循環(huán)查詢。

由于 WordPress 的運(yùn)行方式,這樣做可能會(huì)有些例外。 get_post_meta() 將從數(shù)據(jù)庫(kù)獲取一個(gè)元數(shù)據(jù),如果您正在循環(huán)訪問(wèn)特定文章的元數(shù)據(jù),則可以在循環(huán)中使用它。這是因?yàn)楫?dāng)你第一次使用它的時(shí)候,WordPress 實(shí)際上取得了所有的元數(shù)據(jù)并緩存了起來(lái)。 之后的調(diào)用實(shí)際上是調(diào)用緩存數(shù)據(jù)而不是調(diào)用數(shù)據(jù)庫(kù)。

解決這些問(wèn)題的最好辦法是閱讀函數(shù)文檔并且使用一些類似 查詢監(jiān)聽(tīng)器 的東西。

6. 不要在 SQL 查詢中使用 *

好吧,這更像是一個(gè) MySQL 的問(wèn)題,但我們更傾向于在代碼中編寫 SQL 語(yǔ)句,所以我說(shuō)這是個(gè)公平的游戲。不管什么情況下,如果你能避免使用通配符,那就不要使用,尤其是當(dāng)你的數(shù)據(jù)庫(kù)有很多字段的時(shí)候。

明確指定你需要的字段,并且只檢索這些字段。這有助于節(jié)省內(nèi)存,保護(hù)數(shù)據(jù),并且能讓事情變得更加清晰明白。

在 SQL 方面,盡可能的了解你可用的函數(shù)并測(cè)試速度。 當(dāng)計(jì)算平均數(shù),求和以及計(jì)算相似的數(shù)字的時(shí)候,使用 SQL 內(nèi)置函數(shù)而不是 PHP 的函數(shù)。 如果你不確定一個(gè)查詢的速度快慢,測(cè)試一下它并和其他做法進(jìn)行比較,選出最好的那一種。

7. 不要信任用戶的輸入

信任用戶輸入并不明智。對(duì)于用戶輸入,總是需要過(guò)濾,殺毒,轉(zhuǎn)義,校驗(yàn)以及使用回退。 用戶輸入存在三個(gè)問(wèn)題:我們開(kāi)發(fā)者不可能考慮到所有可能性,經(jīng)常出錯(cuò),存心的惡意輸入。

一個(gè)經(jīng)過(guò)深思熟慮的系統(tǒng)可以防止所有的這些問(wèn)題。 在使用數(shù)據(jù)庫(kù)時(shí),確保使用內(nèi)置的函數(shù),如 filter_var(),來(lái)檢查合法性,進(jìn)行轉(zhuǎn)義,和其他能做的事。

WordPress 有一堆函數(shù)可以幫到你。可以瞧一瞧這篇文章來(lái)了解更多信息 Validating, escaping and sanitising user data 。

8. 不要自作聰明

你的目標(biāo)就是寫出能清晰的表達(dá)你的意愿的優(yōu)雅代碼??赡苣阃ㄟ^(guò)縮短變量名,使用多層級(jí)三目邏輯運(yùn)算和其他小聰明讓每個(gè)頁(yè)面節(jié)約了0.01秒的加載時(shí)間,但是和因此種下你和你的團(tuán)隊(duì)頭疼不已難以維護(hù)的惡果相比,得不償失。

恰當(dāng)?shù)拿兞?,以?jiǎn)潔明了的方式寫出代碼文檔。更好的做法就是,使用標(biāo)準(zhǔn)化的面向?qū)ο蟮拇a風(fēng)格,或多或少的編寫文檔,而非使用大量的內(nèi)聯(lián)代碼注釋。

9. 不要重復(fù)造輪子

PHP 已經(jīng)存在有一段時(shí)間了,網(wǎng)站開(kāi)發(fā)存在的時(shí)間甚至更久遠(yuǎn)。 無(wú)論你做過(guò)啥,前人肯定已經(jīng)做過(guò)。不要害怕依賴別人的支持, Github, Composer , Packagist 都是你的良師益友。

從日志到顏色處理器,從分析器到單元測(cè)試框架,從 Mailchimp APIs 到 Twitter Bootstrap,所有的東西只需要按一個(gè)按鈕(或者敲一個(gè)命令)就能用,去使用它們吧!

10. 不要忽視其他語(yǔ)言

如果你是個(gè) PHPer,現(xiàn)在的標(biāo)準(zhǔn)做法是至少了解 HTML,CSS,Javascript 和 MySQL。 當(dāng)你能很好的處理這些語(yǔ)言的時(shí)候,就是再去學(xué)習(xí)一遍 Javascript 的時(shí)候。Javascript 不是 jQuery。你應(yīng)該學(xué)習(xí) Javascript 來(lái)有效的利用 jQuery。

我也建議學(xué)習(xí) PHP 面向?qū)ο蟮囊磺小K莻€(gè)救星,能讓你的代碼在數(shù)量級(jí)上得到提升。它也能打開(kāi)類似 C# 和 Java 語(yǔ)言的大門,在你有了這些經(jīng)驗(yàn)后,它們能讓你更容易明白面向?qū)ο缶幊蹋∣OP)。

通過(guò)學(xué)習(xí)包管理,構(gòu)建腳本,Coffeescript, LESS, SASS, YAML, 模板引擎以及其他有用的工具來(lái)擴(kuò)展知識(shí)面。我也由衷的推薦看看其他框架,尤其是 Laravel 。

當(dāng)你這些都做得夠好了的時(shí)候,考慮下 Ruby, Ruby on Rails 以及 Android,iPhone,Windows Phone 的 app 開(kāi)發(fā)? 你可能認(rèn)為這些毫無(wú)意義,因?yàn)樗鼈儾辉谀愕氖孢m區(qū)和工作需求之內(nèi),但它們恰恰是重點(diǎn)。 每種語(yǔ)言都有一些有用的教學(xué)知識(shí)和一些無(wú)害的額外知識(shí)。所有頂尖的PHP開(kāi)發(fā)人員都了解其他編程語(yǔ)言,這不是偶然的!

上述就是小編為大家分享的有哪些需要在PHP中避免的問(wèn)題了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

php
AI