搜尋
首頁後端開發php教程PHP 框架:需要避免的隱藏錯誤

PHP Frameworks: hidden errors to avoid

Symfony(撰寫本文時為 7.2)或 Laravel 等框架是高度可定制的,並且無論您的經驗和技能如何,都鼓勵良好的實踐。

但是,您仍然可能會引入設計、安全或效能問題。

Symfony:不要直接呼叫 $container

❌ 這是一個經典但仍被開發人員大量使用的:

 class LuckyController extends AbstractController
  {
      public function index()
       {
        $myDependency = $this->container->get(MyDependencyInterface::class);
        // 
       }

這是可能的,因為父 AbstractController 將 $container 定義為 protected:

protected ContainerInterface $container;

來源:Symfony - GitHub

雖然它確實有效,但由於多種原因,這是一個不好的做法:

  • 它會損害可讀性
  • 測試更難
  • 它依賴全域狀態($container)
  • 隨著 Symfony 的發展,它可能會在未來導致不相容問題

✅ 在建構函式中使用依賴注入:

 class LuckyController extends AbstractController
  {
      public function __construct(private MyDependencyInterface $myDependency) {}

Eloquent ORM:不要盲目使用原始查詢

Eloquent 允許非常方便地編寫 SQL 查詢。

開發人員可以使用 PHP 包裝器與資料庫實體交互,而不是直接編寫 SQL 查詢。

它還在後台使用 SQL 綁定,因此即使輸入不受信任,您也可以免費獲得注入保護:

User::where('email', $request->input('email'))->get();

❌但是,當您使用像 whereRaw 這樣的幫助程式時,您可能會引入漏洞:

User::whereRaw('email = "'. $request->input('email'). '"')->get();

✅ 至少,總是使用 SQL 綁定:

User::whereRaw('email = :email', ['email' => $request->input('email')])->get();

注意:上面的例子沒有意義,但它讓事情變得簡單。在現實世界的用例中,您可能需要 whereRaw 來進行最佳化或實作非常具體的 where 條件。

Laravel:CSRF 怎麼樣?

透過 CSRF 攻擊,駭客迫使最終用戶在他們目前經過身份驗證的應用程式上執行不必要的操作。

Laravel 有一個內建機制來防範這種情況。

粗略地說,它添加了一個與您的請求一起發送的令牌(隱藏欄位),因此您可以驗證「經過身份驗證的使用者是實際向應用程式發出請求的人。」

很公平。

❌但是,某些應用程式會跳過此實作。

✅ 是否應該使用內建中間件與此處無關,但請確保您的應用程式免受 CSRF 攻擊。

您可以閱讀此頁面以了解有關 Laravel 中實現的更多詳細資訊。

也請確保 AJAX 請求的安全性。

Eloquent ORM:查詢沒有「自動」優化

Eloquent 允許急切/延遲加載,並支援各種最佳化,例如查詢快取、索引或批次。

但是,它並不能防止所有效能問題,尤其是在大型資料集上。

❌ 這種循環並不罕見:

 class LuckyController extends AbstractController
  {
      public function index()
       {
        $myDependency = $this->container->get(MyDependencyInterface::class);
        // 
       }

但它可能會導致記憶體問題。

✅ 如果可能,更好的方法是利用 Laravel 集合和區塊等幫助器:

protected ContainerInterface $container;

查看文件以了解更多詳細資訊。

注意:它有效,但不要忘記這些助手只是為了簡化實現,因此您必須監視緩慢的查詢和其他瓶頸。

Symfony:SRP 服務

如文件所述:

有用的物件稱為服務,每個服務都位於一個非常特殊的物件中,稱為服務容器。容器可讓您集中建構物件的方式。它讓您的生活更輕鬆,促進強大的架構並且速度超級快!

換句話說,您將編寫自訂服務來處理您的應用程式的特定職責。

❌文檔是正確的。它旨在促進強大的架構,但閱讀違反單一職責原則 (SRP) 的服務並不罕見:

 class LuckyController extends AbstractController
  {
      public function __construct(private MyDependencyInterface $myDependency) {}

✅ 你必須尊重這個原則。測試和維護會更容易。

Symfony:公共服務與私人服務

❌ 使用 Symfony,您可以使用 $container->get('service_id') 來呼叫任何公用服務。

我們之前看到,像這樣呼叫 $container 被認為是一種不好的做法。

您可能無法抗拒將所有服務公開的誘惑,因此您幾乎可以在專案中的任何地方透過它們的 ID 檢索它們。

不要這樣做。

✅ 相反,將大多數自訂服務保持私有並使用相依性注入。

包起來

希望您能夠避免我所說的框架的「潛在錯誤」或「隱藏錯誤」。

如果您不知道如何實現它,請相信該框架,但請注意某些機制可能在預設情況下未啟用。

以上是PHP 框架:需要避免的隱藏錯誤的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
如何檢查PHP會話是否已經開始?如何檢查PHP會話是否已經開始?Apr 30, 2025 am 12:20 AM

在PHP中,可以使用session_status()或session_id()來檢查會話是否已啟動。 1)使用session_status()函數,如果返回PHP_SESSION_ACTIVE,則會話已啟動。 2)使用session_id()函數,如果返回非空字符串,則會話已啟動。這兩種方法都能有效地檢查會話狀態,選擇使用哪種方法取決於PHP版本和個人偏好。

描述一個場景,其中使用會話在Web應用程序中至關重要。描述一個場景,其中使用會話在Web應用程序中至關重要。Apr 30, 2025 am 12:16 AM

sessionsarevitalinwebapplications,尤其是在commercePlatform之前。

如何管理PHP中的並發會話訪問?如何管理PHP中的並發會話訪問?Apr 30, 2025 am 12:11 AM

在PHP中管理並發會話訪問可以通過以下方法:1.使用數據庫存儲會話數據,2.採用Redis或Memcached,3.實施會話鎖定策略。這些方法有助於確保數據一致性和提高並發性能。

使用PHP會話的局限性是什麼?使用PHP會話的局限性是什麼?Apr 30, 2025 am 12:04 AM

PHPsessionshaveseverallimitations:1)Storageconstraintscanleadtoperformanceissues;2)Securityvulnerabilitieslikesessionfixationattacksexist;3)Scalabilityischallengingduetoserver-specificstorage;4)Sessionexpirationmanagementcanbeproblematic;5)Datapersis

解釋負載平衡如何影響會話管理以及如何解決。解釋負載平衡如何影響會話管理以及如何解決。Apr 29, 2025 am 12:42 AM

負載均衡會影響會話管理,但可以通過會話複製、會話粘性和集中式會話存儲解決。 1.會話複製在服務器間複製會話數據。 2.會話粘性將用戶請求定向到同一服務器。 3.集中式會話存儲使用獨立服務器如Redis存儲會話數據,確保數據共享。

說明會話鎖定的概念。說明會話鎖定的概念。Apr 29, 2025 am 12:39 AM

Sessionlockingisatechniqueusedtoensureauser'ssessionremainsexclusivetooneuseratatime.Itiscrucialforpreventingdatacorruptionandsecuritybreachesinmulti-userapplications.Sessionlockingisimplementedusingserver-sidelockingmechanisms,suchasReentrantLockinJ

有其他PHP會議的選擇嗎?有其他PHP會議的選擇嗎?Apr 29, 2025 am 12:36 AM

PHP會話的替代方案包括Cookies、Token-basedAuthentication、Database-basedSessions和Redis/Memcached。 1.Cookies通過在客戶端存儲數據來管理會話,簡單但安全性低。 2.Token-basedAuthentication使用令牌驗證用戶,安全性高但需額外邏輯。 3.Database-basedSessions將數據存儲在數據庫中,擴展性好但可能影響性能。 4.Redis/Memcached使用分佈式緩存提高性能和擴展性,但需額外配

在PHP的上下文中定義'會話劫持”一詞。在PHP的上下文中定義'會話劫持”一詞。Apr 29, 2025 am 12:33 AM

Sessionhijacking是指攻擊者通過獲取用戶的sessionID來冒充用戶。防範方法包括:1)使用HTTPS加密通信;2)驗證sessionID的來源;3)使用安全的sessionID生成算法;4)定期更新sessionID。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

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

熱工具

SublimeText3 Mac版

SublimeText3 Mac版

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

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境