Maison  >  Article  >  cadre php  >  Quel est le problème avec le nouvel ajout de Laravel et l'impossibilité de le modifier ?

Quel est le problème avec le nouvel ajout de Laravel et l'impossibilité de le modifier ?

PHPz
PHPzoriginal
2023-04-23 10:06:26550parcourir

Récemment, lors du développement d'un projet utilisant le framework Laravel, j'ai découvert un problème : les données nouvellement ajoutées ne peuvent pas être modifiées. Après un dépannage et une analyse plus approfondis, j'ai trouvé le problème et je l'ai résolu. Permettez-moi de partager quelques idées de solutions ci-dessous.

Tout d'abord, nous devons clarifier un concept : la méthode de requête HTTP. La méthode de requête HTTP fait référence à la méthode utilisée par le client lors de la demande de ressources au serveur, notamment GET, POST, PUT, DELETE, etc. Parmi elles, la méthode GET est utilisée pour obtenir des ressources, la méthode POST est utilisée pour créer des ressources, la méthode PUT est utilisée pour mettre à jour les ressources et la méthode DELETE est utilisée pour supprimer des ressources.

Dans Laravel, lors de l'utilisation de la soumission de formulaire, la méthode de requête par défaut est POST, par exemple :

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

Ensuite, nous utilisons la méthode store dans le contrôleur pour gérer cette requête : 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');
}
Dans le ci-dessus Dans le code, nous créons un nouvel objet User, attribuons le champ de nom soumis par le formulaire à l'attribut name de l'objet User, puis enregistrons les données et redirigeons vers la page /user.

Cependant, le code ci-dessus présente parfois un problème : les données nouvellement ajoutées ne peuvent pas être modifiées. Lorsque nous accédons à la page d'édition, nous constaterons qu'il n'y a aucune information de données créée à l'origine dans la page. Pourquoi est-ce ? Nous pouvons d'abord jeter un oeil au code de la page d'édition :

rrreee

Dans ce code, nous utilisons la méthode method_field pour spécifier la méthode de requête comme PUT, car dans le protocole HTTP, la mise à jour des ressources nécessite l'utilisation de la méthode PUT. Cependant, dans le framework Laravel, la requête POST par défaut ne peut pas reconnaître la requête PUT. Par conséquent, lors de l'accès à la page d'édition, Laravel la traitera selon la requête POST par défaut au lieu de la requête PUT attendue. 🎜🎜Il existe deux idées pour résoudre ce problème : l'une consiste à utiliser la méthode de requête PUT pour créer des données ; l'autre consiste à utiliser le paramètre _method pour spécifier la méthode de requête lors de l'utilisation de la méthode POST pour créer données. 🎜🎜La première solution est une méthode plus simple, mais elle nécessite plus de modifications de code. Nous devons utiliser la méthode de requête PUT sous la forme : 🎜rrreee🎜 Ensuite, gérer la requête PUT dans le contrôleur : 🎜rrreee🎜En utilisant cette méthode, nous devons spécifier la méthode PUT dans le formulaire, et passer un paramètre _token pour empêcher les attaques CSRF, cela augmentera considérablement la charge de travail du code. 🎜🎜La deuxième solution est beaucoup plus simple. Nous devons utiliser la méthode POST dans le formulaire, mais ajouter le paramètre _method lors de la soumission pour spécifier la méthode de requête comme PUT : 🎜rrreee🎜 Ensuite, lors du traitement de la requête POST dans le contrôleur, utilisez la méthode méthode pour identifier la requête PUT : 🎜rrreee🎜En utilisant cette méthode, il suffit d'ajouter un paramètre _method au formulaire, qui est plus lisible et nécessite moins de travail de codage. 🎜🎜Dans le processus de développement de projets Laravel, il est inévitable de rencontrer des problèmes. La résolution de problèmes nécessite notre patience et notre attention, ainsi qu'une compréhension et une maîtrise approfondies du framework et de la technologie. J'espère que cet article pourra fournir des références et aider les lecteurs. 🎜

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn