十個你需要在 PHP 7 中避免的坑

Charlie_Jade發表於2019-02-16

clipboard.png

1. 不要使用 mysql_ 類函式

終於,你不用再看到建議不要使用 mysql_ 函式的提示了。因為 PHP 7 從核心上完全移除了它們,這意味著請你移步至更好的 mysqli_ 類函式,或者更靈活的 PDO 層。

2. 不要寫無用的程式碼

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

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

作為開發者,應該確保按需載入指令碼,可能時再組合,編寫高效的資料庫查詢語句,如果可能的話 使用快取 等等。

3. 不要在檔案末尾使用 PHP 閉合標籤

如果你隨便看看,就會發現大部分 WordPress 核心程式碼檔案結尾都省略了 PHP 閉合標籤。事實上,Zend 框架尤為明顯地 禁止了閉合標籤。它並非 PHP 所必須,在檔案結尾處省略它,可確保結尾無額外空白。

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

我個人非常不喜歡引用傳參。我當然知道在某些場合下它很有用,但是多數場合下,它會使得程式碼難以理解,難以遵循,難以預測結果。

人們認為引用可以使它們的程式碼更快,不過正如 可敬的 PHP 程式設計師 的這篇文章所指出的,事實並非如此。

PHP 內建的 shuffle() 或者 sort() 函式,就是糟糕的引用傳參案例。 它修改了原陣列而不是返回一個打亂的或者排好序的陣列,這是完全違背了我們意願的。

5. 不要在迴圈裡使用查詢

在迴圈中使用資料庫查詢時最糟糕的。他會給系統帶來不必要的壓力,並且很有可能,你可以在迴圈外使用查詢而更快的得到相同的結果。當我碰到必須這樣用的場景時,我通常會通過分成兩個查詢來構造一個陣列的方式來解決。然後迴圈陣列而無需迴圈查詢。

由於 WordPress 的執行方式,這樣做可能會有些例外。 get_post_meta() 將從資料庫獲取一個後設資料,如果您正在迴圈訪問特定文章的後設資料,則可以在迴圈中使用它。這是因為當你第一次使用它的時候,WordPress 實際上取得了所有的後設資料並快取了起來。 之後的呼叫實際上是呼叫快取資料而不是呼叫資料庫。

解決這些問題的最好辦法是閱讀函式文件並且使用一些類似 查詢監聽器 的東西。

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

好吧,這更像是一個 MySQL 的問題,但我們更傾向於在程式碼中編寫 SQL 語句,所以我說這是個公平的遊戲。不管什麼情況下,如果你能避免使用萬用字元,那就不要使用,尤其是當你的資料庫有很多欄位的時候。

明確指定你需要的欄位,並且只檢索這些欄位。這有助於節省記憶體,保護資料,並且能讓事情變得更加清晰明白。

在 SQL 方面,儘可能的瞭解你可用的函式並測試速度。 當計算平均數,求和以及計算相似的數字的時候,使用 SQL 內建函式而不是 PHP 的函式。 如果你不確定一個查詢的速度快慢,測試一下它並和其他做法進行比較,選出最好的那一種。

7. 不要信任使用者的輸入

信任使用者輸入並不明智。對於使用者輸入,總是需要過濾,防毒,轉義,校驗以及使用回退。 使用者輸入存在三個問題:我們開發者不可能考慮到所有可能性,經常出錯,存心的惡意輸入。

一個經過深思熟慮的系統可以防止所有的這些問題。 在使用資料庫時,確保使用內建的函式,如 filter_var(),來檢查合法性,進行轉義,和其他能做的事。

WordPress 有一堆函式可以幫到你。可以瞧一瞧這篇文章來了解更多資訊 Validating, escaping and sanitising user data 。

8. 不要自作聰明

你的目標就是寫出能清晰的表達你的意願的優雅程式碼。可能你通過縮短變數名,使用多層級三目邏輯運算和其他小聰明讓每個頁面節約了0.01秒的載入時間,但是和因此種下你和你的團隊頭疼不已難以維護的惡果相比,得不償失。

恰當的命名變數,以簡潔明瞭的方式寫出程式碼文件。更好的做法就是,使用標準化的物件導向的程式碼風格,或多或少的編寫文件,而非使用大量的內聯程式碼註釋。

9. 不要重複造輪子

PHP 已經存在有一段時間了,網站開發存在的時間甚至更久遠。 無論你做過啥,前人肯定已經做過。不要害怕依賴別人的支援, Github, Composer , Packagist 都是你的良師益友。

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

10. 不要忽視其他語言

如果你是個 PHPer,現在的標準做法是至少了解 HTML,CSS,Javascript 和 MySQL。 當你能很好的處理這些語言的時候,就是再去學習一遍 Javascript 的時候。Javascript 不是 jQuery。你應該學習 Javascript 來有效的利用 jQuery。

我也建議學習 PHP 物件導向的一切。它是個救星,能讓你的程式碼在數量級上得到提升。它也能開啟類似 C# 和 Java 語言的大門,在你有了這些經驗後,它們能讓你更容易明白麵向物件程式設計(OOP)。

通過學習包管理,構建指令碼,Coffeescript, LESS, SASS, YAML, 模板引擎以及其他有用的工具來擴充套件知識面。我也由衷的推薦看看其他框架,尤其是 Laravel 。

當你這些都做得夠好了的時候,考慮下 Ruby, Ruby on Rails 以及 Android,iPhone,Windows Phone 的 app 開發? 你可能認為這些毫無意義,因為它們不在你的舒適區和工作需求之內,但它們恰恰是重點。 每種語言都有一些有用的教學知識和一些無害的額外知識。所有頂尖的PHP開發人員都瞭解其他程式語言,這不是偶然的!

更多現代化 PHP 知識,請前往 Laravel / PHP 知識社群

相關文章