最近在使用 Laravel 框架開發專案時,發現一個問題:新增的資料無法編輯。在進一步排查和分析之後,我發現了問題所在並解決了這個問題。下面就分享一下解決思路。
首先,我們需要先明確一個概念-HTTP 請求方法。 HTTP 請求方法是指客戶端在向伺服器要求資源時所使用的方法,包括 GET、POST、PUT、DELETE 等。其中,GET 方法用於取得資源,POST 方法用於建立資源,PUT 方法用於更新資源,DELETE 方法用於刪除資源。
在Laravel 中,使用表單提交時,預設請求方法是POST,例如:
然後,我們在控制器中使用store
方法來處理這個請求:
public function store(Request $request) { $user = new User; $user->name = $request->input('name'); $user->save(); return redirect('/user'); }
在上面的程式碼中,我們建立了一個新的User 對象,將表單提交的name 欄位賦值給User 物件的name 屬性,然後儲存資料並重定向到/user
頁面。
但是,上述程式碼有時候會出現一個問題:新增的資料無法編輯。我們在存取編輯頁面時,會發現頁面中沒有原先建立的資料資訊。這是為什麼呢?我們可以先看一下編輯頁面的程式碼:
在這個程式碼中,我們使用了method_field
方法來指定請求方法為PUT,因為在HTTP 協定中,更新資源需要使用PUT 方法。但是,在 Laravel 框架中,預設的 POST 請求是無法識別 PUT 請求的,因此,在存取編輯頁面時,Laravel 會根據預設的 POST 請求來處理,而不是按照我們期望的 PUT 請求來處理。
解決這個問題的想法有兩個:一是使用 PUT 請求方法來建立資料;二是在使用 POST 方法建立資料時,使用 _method
參數來指定請求方法。
第一種解決想法是比較乾脆的方法,但是需要改變較多的程式碼。我們需要在表單中使用PUT 請求方法:
然後,在控制器中處理PUT 請求:
public function update(Request $request, $id) { $user = User::findOrFail($id); $user->name = $request->input('name'); $user->save(); return redirect('/user'); }
使用這種方式,我們需要在表單中指定採用PUT 方法,並且需要傳遞一個_token 參數來防止CSRF 攻擊,這會增加不少的程式碼工作量。
第二種解決思路則簡單得多。我們需要在表單中使用POST 方法,但是在提交時加上_method 參數指定請求方法為PUT:
然後,在控制器中處理POST 請求時,使用method
方法來識別PUT 請求:
public function update(Request $request, $id) { $user = User::findOrFail($id); $user->name = $request->input('name'); $user->save(); return redirect('/user'); }
使用這種方式,我們只需要在表單中加上一個_method 參數即可,可讀性較高,程式碼工作量少。
在開發 Laravel 專案的過程中,遇到問題是必然的,解決問題需要我們耐心和細心,以及對框架和技術的深入理解和掌握。希望本文能為讀者提供一些參考與協助。
以上是laravel新增不能編輯怎麼回事的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本文指導建立強大的Laravel Restful Apis。 它涵蓋項目設置,資源管理,數據庫交互,序列化,身份驗證,授權,測試和關鍵的安全性最佳實踐。 解決可伸縮性chall

本文詳細介紹了Laravel實施OAuth 2.0身份驗證和授權。 它涵蓋了使用League/oauth2-server或提供商特定解決方案的軟件包,強調數據庫設置,客戶端註冊,授權服務器Configu

本文討論了使用組件在Laravel中創建和自定義可重複使用的UI元素,從而為組織提供最佳實踐並建議增強包裝。

本文討論了在雲本地環境中部署Laravel的最佳實踐,重點是可擴展性,可靠性和安全性。關鍵問題包括容器化,微服務,無狀態設計和優化策略。

本文討論了Laravel中的創建和使用自定義刀片指令以增強模板。它涵蓋了定義指令,在模板中使用它們,並在大型項目中管理它們,強調了改進的代碼可重複性和R等好處

本文討論了Laravel中的創建和使用自定義驗證規則,提供了定義和實施的步驟。它突出了諸如可重複性和特異性之類的好處,並提供了擴展Laravel驗證系統的方法。

在選擇PHP框架方面,Laravel和Symfony是最受歡迎和廣泛使用的選項之一。每個框架都為桌子帶來了自己的理念,特徵和優勢,使它們適合不同的項目和用例

本文探討了Laravel中最佳的文件上傳和雲存儲策略。 它檢查本地存儲與雲提供商(AWS S3,Google Cloud,Azure,Digitalocean),強調安全性(驗證,消毒,HTTPS)和Performance Opti


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

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

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具

Dreamweaver CS6
視覺化網頁開發工具

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