laravel의 새로운 추가 기능과 이를 편집할 수 없는 문제는 무엇입니까?
최근 Laravel 프레임워크를 사용하여 프로젝트를 개발할 때 새로 추가된 데이터를 편집할 수 없다는 문제를 발견했습니다. 추가 문제 해결 및 분석을 통해 문제를 찾아 해결했습니다. 아래에 몇 가지 솔루션 아이디어를 공유하겠습니다.
우선 HTTP 요청 방식이라는 개념을 명확히 해야 합니다. HTTP 요청 방식은 클라이언트가 서버에 자원을 요청할 때 사용하는 방식으로 GET, POST, PUT, DELETE 등이 있습니다. 그 중 GET 메소드는 리소스 획득에 사용되고, POST 메소드는 리소스 생성에 사용되고, PUT 메소드는 리소스 업데이트에 사용되고, DELETE 메소드는 리소스 삭제에 사용된다.
Laravel에서 양식 제출을 사용할 때 기본 요청 방법은 POST입니다. 예:
<form action="/user" method="POST"> <input type="text" name="name"> <button type="submit">提交</button> </form>
그런 다음 컨트롤러의 store
메서드를 사용하여 이 요청을 처리합니다. 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'); }
/user
페이지로 리디렉션합니다. 그러나 위 코드에는 때때로 문제가 있습니다. 새로 추가된 데이터를 편집할 수 없습니다. 편집 페이지에 접속해 보면 해당 페이지에는 원래 생성된 데이터 정보가 없다는 것을 알 수 있습니다. 왜 이런거야? 먼저 편집 페이지의 코드를 살펴보겠습니다. rrreee
이 코드에서는method_field
메서드를 사용하여 요청 메서드를 PUT으로 지정합니다. 왜냐하면 HTTP 프로토콜에서 리소스를 업데이트하려면 다음이 필요하기 때문입니다. PUT 방식을 사용합니다. 그러나 Laravel 프레임워크에서는 기본 POST 요청이 PUT 요청을 인식할 수 없으므로, Laravel은 편집 페이지에 접근할 때 우리가 기대하는 PUT 요청 대신 기본 POST 요청에 따라 처리합니다. 🎜🎜이 문제를 해결하기 위한 두 가지 아이디어가 있습니다. 하나는 PUT 요청 메소드를 사용하여 데이터를 생성하는 것이고, 다른 하나는 POST 메소드를 사용하여 데이터를 생성할 때 _method
매개변수를 사용하여 요청 메소드를 지정하는 것입니다. 데이터. 🎜🎜첫 번째 해결 방법은 더 간단한 방법이지만 더 많은 코드 변경이 필요합니다. 🎜rrreee🎜 형식의 PUT 요청 메서드를 사용해야 합니다. 그런 다음 컨트롤러에서 PUT 요청을 처리합니다. 🎜rrreee🎜이 메서드를 사용하여 형식에 PUT 메서드를 지정하고 _token 매개변수를 전달해야 합니다. CSRF 공격을 방지하기 위해 코드 작업량이 많이 증가합니다. 🎜🎜두 번째 해결 방법은 훨씬 간단합니다. 양식에서 POST 메서드를 사용해야 하지만 제출 시 _method 매개변수를 추가하여 요청 메서드를 PUT으로 지정합니다. 🎜rrreee🎜 그런 다음 컨트롤러에서 POST 요청을 처리할 때 메서드
를 사용하세요. PUT 요청을 식별하는 방법: 🎜rrreee🎜이 방법을 사용하면 양식에 _method 매개변수만 추가하면 되기 때문에 더 읽기 쉽고 코딩 작업이 덜 필요합니다. 🎜🎜Laravel 프로젝트를 개발하는 과정에서 문제가 발생하는 것은 불가피합니다. 문제를 해결하려면 인내심과 주의가 필요하며, 프레임워크와 기술에 대한 심층적인 이해와 숙달이 필요합니다. 이 글이 독자들에게 참고가 되고 도움이 되기를 바랍니다. 🎜위 내용은 laravel의 새로운 추가 기능과 이를 편집할 수 없는 문제는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











이 기사는 강력한 Laravel Restful API를 구축하는 사람들을 안내합니다. 프로젝트 설정, 리소스 관리, 데이터베이스 상호 작용, 직렬화, 인증, 인증, 테스트 및 중요한 보안 모범 사례를 다룹니다. 확장 성 도전 해결

이 기사는 Laravel에서 OAUTH 2.0 인증 및 승인을 구현하는 자세한 내용입니다. 리그/OAUTH2-SERVER 또는 제공자 별 솔루션과 같은 패키지를 사용하여 데이터베이스 설정 강조, 클라이언트 등록, 인증 서버 Configu

이 기사는 구성 요소를 사용하여 Laravel에서 재사용 가능한 UI 요소를 작성하고 사용자 정의하여 조직을위한 모범 사례를 제공하고 패키지 강화를 제안합니다.

이 기사에서는 Laravel에서 사용자 정의 검증 규칙을 작성하고 사용하여이를 정의하고 구현하는 단계를 제공합니다. 재사용 성과 특이성과 같은 이점을 강조하고 Laravel의 검증 시스템을 확장하는 방법을 제공합니다.

이 기사는 클라우드 네이티브 환경에서 Laravel을 배포하기위한 모범 사례에 대해 설명하고 확장 성, 신뢰성 및 보안에 중점을 둡니다. 주요 문제로는 컨테이너화, 마이크로 서비스, 무국적 설계 및 최적화 전략이 포함됩니다.

PHP 프레임 워크를 선택할 때 Laravel과 Symfony는 가장 인기 있고 널리 사용되는 옵션 중 하나입니다. 각 프레임 워크는 자체 철학, 기능 및 강점을 테이블에 제공하여 다양한 프로젝트 및 사용 사례에 적합합니다.

이 기사는 Laravel에서 사용자 정의 블레이드 지시문을 만들고 사용하여 템플릿을 향상시키는 것에 대해 설명합니다. 지침 정의, 템플릿에서이를 사용하고 대규모 프로젝트에서 관리하고 개선 된 코드 재사용 성 및 R과 같은 이점을 강조합니다.

Laravel의 Artisan Console은 코드 생성, 마이그레이션 실행 및 스케줄링과 같은 작업을 자동화합니다. 주요 명령에는 Make : Controller, Migrate 및 DB : SEED가 포함됩니다. 특정 요구에 대해 사용자 정의 명령을 작성할 수 있으며 워크 플로 효율 향상.
