php7中的10禁忌
1. 不要使用 mysql_ 函數
這一天終於來了,從此你不僅僅「不應該」使用mysql_函數。 PHP 7 已經把它們從核心中全部移除了,也就是說你需要遷移到好得多的mysqli_函數,或者更靈活的 PDO 實作。
2. 不要寫垃圾程式碼
這一則可能易於理解,但會變得越來越重要,因為 PHP 7 的速度提升可能會隱藏你的一些問題。不要只滿足於你的網站速度,因為遷移到 PHP 7 才會讓它變快。
為了理解速度有多重要,以及如何把事情做得更好,請看一看我們的文章速度優化入門指南。
作為一名開發者,你應該總是確保按需加載腳本,盡可能連接它們,編寫高效的資料庫查詢,盡可能使用緩存,以及其它。
3. 不要在檔案最後使用 PHP 閉合標籤
你可以看一看,當一個檔案以 PHP 程式碼結尾時,WordPress 多數核心程式碼都把結尾的 PHP 標籤去掉了。實際上,Zend 框架特別禁止了它。 PHP 並不需要文件末尾的閉合標籤,我們可以透過去掉它來確保不會在後面添加任何的空白字元。
4. 不要做不必要的引用傳遞
我個人不喜歡引用傳遞。我知道有時候它很實用,但是其它情況下它使程式碼變得難懂,並且更難預測結果。
據說有些人認為它使程式碼運行更快,但是根據一些 PHP 高級程式設計師所說,這並不正確。
說明引用為什麼不好的例子是,PHP 內建了shuffle()和sort()。它們修改原始數組,而不是傳回處理後的數組,這很不合邏輯。
5. 不要在循環中執行查詢
在循環中執行查詢非常浪費。它給你的系統施加不必要的壓力,並且可能能夠在循環外部更快獲得相同結果。當我遇到需要這樣的情況時,我通常會使用兩個分離的查詢來解決問題,我會使用它們來建立資料數組。之後我會遍歷數組,並不需要在這個過程中執行查詢。
由於 WordPress 適用於這裡,它可能有一些例外。雖然get_post_meta() 會從資料庫獲取大量數據,如果你正在遍歷某個特殊博文的元數據你可以在循環中使用它。這是因為當你第一次呼叫它的時候,WordPress實際上會取得所有元資料並快取它們。後續的呼叫使用這些快取數據,沒有資料庫的呼叫。
弄懂這些的最佳方式是閱讀函數文檔,以及使用類似 Query Monitor 的工具。
6. 不要在 SQL 查詢中使用 *
當然,這個更像 MySQL 的問題,但是我們習慣在 PHP 中編寫 SQL 程式碼,所以都差不多。無論如何,如果可以避免的話,不要在 SQL 查詢裡使用通配符,尤其是資料庫有很多列的時候。
你應該明確指定需要哪些行,並且僅僅獲取它們。這有助於減少所用資源,保護數據,並讓事情變得盡可能清晰。
對於 SQL,你需要了解所有可用的函數,並且盡可能測試其速度。在計算平均值、求和或計算類似數值時,請使用 SQL 函數而不是 PHP 函數。如果你不確定某個查詢的速度,測試它並且嘗試一些其它的編譯 — 之後使用最好的那個。
7. 不要信任使用者輸入
信任使用者輸入是不明智的。始終校驗、過濾、轉義、檢查並留好退路。使用者資料有三個問題:我們開發者並沒有考慮每種可能性,它通常不正確,以及它可能是蓄意破壞。
經過周密考慮的系統可以防護這些威脅。若要確保使用類似filter_var()的內建函數檢查適當的值,以及在處理資料庫時轉義(或預先編譯)。
WordPress 擁有一些函數來解決問題。詳見文章校驗、轉義和過濾使用者資料。
8. 不要故作聰明
你的目標應該是寫出優雅的程式碼,來更清晰地表達你的意圖。你可能能夠透過將任何東西縮短為一個單字的變量,使用多層的三元邏輯,以及其它手段,從每個頁面中優化 0.01 秒。但這只會給你和你周圍的人產生大麻煩。
合理命名變量,為程式碼編寫文檔,優先選擇清晰而不是簡潔。甚至可以更好,使用標準的物件導向程式碼,它本身或多或少就是文檔,不需要一大堆內聯數值。
9. 不要重新發明輪子
PHP 到現在為止有很長時間了,網站被造出來的時間更長。很可能無論你需要造什麼,有些人之前早就造出來了。不要害怕向他人尋求支持,Github是你的好朋友,Composer也是,Packagist也是。
從日誌工具到調色工具,從效能分析器到單元測試框架,從 Mailchimp API 到 Twitter Bootstrap,每個東西都可以透過按下按鍵(或敲下指令)來獲取,使用它們吧!
10. 不要忽略其它語言
如果你是個 PHP 程式設計師,現在有個好機會去至少了解 HTML、CSS、JavaScript 和 MySQL。當你能夠更好地處理這些語言時,就是重新學習 JavaScript 的時機了。 JavaScript 並不是 jQuery,你應該合理地學習 JavaScript 來更有效率地使用它。
我也打算向你推薦學習物件導向的 PHP,它可以節省時間,並且在程式碼規模更大時會變得更好。對於類似 C# 和 Java 的語言,在你了解 OOP 之後,它們也更容易理解。
透過了解套件管理器、建置腳本、CoffeeScript、LESS、SASS、YAML 、腳本引擎和其它強大的工具來擴展你的知識面。我強烈推薦你去看其它框架,尤其是 Laravel。
當你使用它們出色完成任務時,學習 Ruby、RoR、Android、iPhone 和 Windows Phone 應用程式開發如何?你可能會認為這毫無意義,因為它們在你的舒適區和工作所需範圍之外,但這就是它們的意義。每種語言都有一些要學習的實用的東西,以及從未碰到的新知識。所有 PHP 頂級開發者都懂得許多其它程式語言,這並非偶然。

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

JWT是一種基於JSON的開放標準,用於在各方之間安全地傳輸信息,主要用於身份驗證和信息交換。 1.JWT由Header、Payload和Signature三部分組成。 2.JWT的工作原理包括生成JWT、驗證JWT和解析Payload三個步驟。 3.在PHP中使用JWT進行身份驗證時,可以生成和驗證JWT,並在高級用法中包含用戶角色和權限信息。 4.常見錯誤包括簽名驗證失敗、令牌過期和Payload過大,調試技巧包括使用調試工具和日誌記錄。 5.性能優化和最佳實踐包括使用合適的簽名算法、合理設置有效期、

會話劫持可以通過以下步驟實現:1.獲取會話ID,2.使用會話ID,3.保持會話活躍。在PHP中防範會話劫持的方法包括:1.使用session_regenerate_id()函數重新生成會話ID,2.通過數據庫存儲會話數據,3.確保所有會話數據通過HTTPS傳輸。

SOLID原則在PHP開發中的應用包括:1.單一職責原則(SRP):每個類只負責一個功能。 2.開閉原則(OCP):通過擴展而非修改實現變化。 3.里氏替換原則(LSP):子類可替換基類而不影響程序正確性。 4.接口隔離原則(ISP):使用細粒度接口避免依賴不使用的方法。 5.依賴倒置原則(DIP):高低層次模塊都依賴於抽象,通過依賴注入實現。

在PHPStorm中如何進行CLI模式的調試?在使用PHPStorm進行開發時,有時我們需要在命令行界面(CLI)模式下調試PHP�...

PHP8.1中的枚舉功能通過定義命名常量增強了代碼的清晰度和類型安全性。 1)枚舉可以是整數、字符串或對象,提高了代碼可讀性和類型安全性。 2)枚舉基於類,支持面向對象特性,如遍歷和反射。 3)枚舉可用於比較和賦值,確保類型安全。 4)枚舉支持添加方法,實現複雜邏輯。 5)嚴格類型檢查和錯誤處理可避免常見錯誤。 6)枚舉減少魔法值,提升可維護性,但需注意性能優化。

如何在系統重啟後自動設置unixsocket的權限每次系統重啟後,我們都需要執行以下命令來修改unixsocket的權限:sudo...

靜態綁定(static::)在PHP中實現晚期靜態綁定(LSB),允許在靜態上下文中引用調用類而非定義類。 1)解析過程在運行時進行,2)在繼承關係中向上查找調用類,3)可能帶來性能開銷。
