Heim  >  Artikel  >  PHP-Framework  >  Was ist falsch an Laravels Neuzugang und der Unfähigkeit, ihn zu bearbeiten?

Was ist falsch an Laravels Neuzugang und der Unfähigkeit, ihn zu bearbeiten?

PHPz
PHPzOriginal
2023-04-23 10:06:26528Durchsuche

Bei der Entwicklung eines Projekts mit dem Laravel-Framework habe ich kürzlich ein Problem entdeckt: Die neu hinzugefügten Daten können nicht bearbeitet werden. Nach weiterer Fehlerbehebung und Analyse habe ich das Problem gefunden und gelöst. Lassen Sie mich unten einige Lösungsideen teilen.

Zunächst müssen wir ein Konzept klären – die HTTP-Anfragemethode. Die HTTP-Anforderungsmethode bezieht sich auf die Methode, die der Client verwendet, wenn er Ressourcen vom Server anfordert, einschließlich GET, POST, PUT, DELETE usw. Unter diesen wird die GET-Methode zum Abrufen von Ressourcen, die POST-Methode zum Erstellen von Ressourcen, die PUT-Methode zum Aktualisieren von Ressourcen und die DELETE-Methode zum Löschen von Ressourcen verwendet.

In Laravel ist bei der Formularübermittlung die Standardanforderungsmethode POST, zum Beispiel:

<form action="/user" method="POST">
    <input type="text" name="name">
    <button type="submit">提交</button>
</form>

Dann verwenden wir store im Controller Methode zur Bearbeitung dieser Anfrage: store 方法来处理这个请求:

public function store(Request $request)
{
    $user = new User;
    $user->name = $request->input('name');
    $user->save();
    return redirect('/user');
}

在上面的代码中,我们创建了一个新的 User 对象,将表单提交的 name 字段赋值给 User 对象的 name 属性,然后保存数据并重定向到 /user 页面。

但是,上述代码有时候会出现一个问题:新增的数据无法编辑。我们在访问编辑页面时,会发现页面中没有原先创建的数据信息。这是为什么呢?我们可以先看一下编辑页面的代码:

<form action="/user/{{ $user->id }}" method="POST">
    {{ method_field('PUT') }}
    <input type="text" name="name" value="{{ $user->name }}">
    <button type="submit">提交</button>
</form>

在这个代码中,我们使用了 method_field 方法来指定请求方法为 PUT,因为在 HTTP 协议中,更新资源需要使用 PUT 方法。但是,在 Laravel 框架中,默认的 POST 请求是无法识别 PUT 请求的,因此,在访问编辑页面时,Laravel 会根据默认的 POST 请求来处理,而不是按照我们期望的 PUT 请求来处理。

解决这个问题的思路有两个:一是使用 PUT 请求方法来创建数据;二是在使用 POST 方法创建数据时,使用 _method 参数来指定请求方法。

第一种解决思路是比较干脆的方法,但是需要改动较多的代码。我们需要在表单中使用 PUT 请求方法:

<form action="/user/{{ $user->id }}" method="POST">
    {{ method_field('PUT') }}
    <input type="hidden" name="_token" value="{{ csrf_token() }}">
    <input type="text" name="name" value="{{ $user->name }}">
    <button type="submit">提交</button>
</form>

然后,在控制器中处理 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:

<form action="/user/{{ $user->id }}" method="POST">
    <input type="hidden" name="_method" value="PUT">
    <input type="hidden" name="_token" value="{{ csrf_token() }}">
    <input type="text" name="name" value="{{ $user->name }}">
    <button type="submit">提交</button>
</form>

然后,在控制器中处理 POST 请求时,使用 method

public function update(Request $request, $id)
{
    $user = User::findOrFail($id);
    $user->name = $request->input('name');
    $user->save();
    return redirect('/user');
}
Im obigen Code erstellen wir ein neues Benutzerobjekt, weisen das vom Formular übermittelte Namensfeld dem Namensattribut des Benutzerobjekts zu und speichern dann die Daten und Weiterleitung zur Seite /user.

Der obige Code weist jedoch manchmal ein Problem auf: Die neu hinzugefügten Daten können nicht bearbeitet werden. Wenn wir auf die Bearbeitungsseite zugreifen, werden wir feststellen, dass auf der Seite keine ursprünglich erstellten Dateninformationen vorhanden sind. Warum ist das so? Wir können uns zunächst den Code der Bearbeitungsseite ansehen:

rrreee

In diesem Code verwenden wir die Methode method_field, um die Anforderungsmethode als PUT anzugeben, da in der HTTP-Protokoll, Update-Ressourcen erfordern die PUT-Methode. Im Laravel-Framework kann die Standard-POST-Anfrage die PUT-Anfrage jedoch nicht erkennen. Daher verarbeitet Laravel sie beim Zugriff auf die Bearbeitungsseite gemäß der Standard-POST-Anfrage und nicht gemäß der von uns erwarteten PUT-Anfrage. #🎜🎜##🎜🎜#Es gibt zwei Ideen, um dieses Problem zu lösen: Eine besteht darin, die PUT-Anforderungsmethode zum Erstellen von Daten zu verwenden, die andere darin, den Parameter _method zu verwenden, um die Anforderung bei der Verwendung anzugeben die POST-Methode zum Erstellen von Daten. #🎜🎜##🎜🎜#Die erste Lösung ist eine einfachere Methode, erfordert jedoch mehr Codeänderungen. Wir müssen die PUT-Anfragemethode in der Form verwenden: #🎜🎜#rrreee#🎜🎜#Dann verarbeiten wir die PUT-Anfrage im Controller: #🎜🎜#rrreee#🎜🎜#Mit dieser Methode müssen wir die Methode angeben in der PUT-Methode und muss einen _token-Parameter übergeben, um CSRF-Angriffe zu verhindern, was die Code-Arbeitslast erheblich erhöhen wird. #🎜🎜##🎜🎜#Die zweite Lösung ist viel einfacher. Wir müssen die POST-Methode im Formular verwenden, aber beim Absenden den Parameter _method hinzufügen, um die Anforderungsmethode als PUT anzugeben: #🎜🎜#rrreee#🎜🎜#Verwenden Sie dann bei der Verarbeitung der POST-Anfrage im Controller method Methode zur Identifizierung von PUT-Anfragen: #🎜🎜#rrreee#🎜🎜#Mit dieser Methode müssen wir dem Formular nur einen _method-Parameter hinzufügen, der besser lesbar ist und weniger Codierungsaufwand erfordert. #🎜🎜##🎜🎜# Bei der Entwicklung von Laravel-Projekten ist es unvermeidlich, auf Probleme zu stoßen. Die Lösung von Problemen erfordert unsere Geduld und Sorgfalt sowie ein tiefes Verständnis und die Beherrschung des Frameworks und der Technologie. Ich hoffe, dass dieser Artikel den Lesern Hinweise und Hilfe bieten kann. #🎜🎜#

Das obige ist der detaillierte Inhalt vonWas ist falsch an Laravels Neuzugang und der Unfähigkeit, ihn zu bearbeiten?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn