먼저 게시할 기사를 추가하도록 라우팅을 수정하겠습니다.
<code>Route::get('articles/create', 'ArticlesController@create');</code>
그런 다음 컨트롤러를 수정하세요
<code> public function create() { return view('articles.create'); }</code>
뷰를 반환하고 새 뷰를 만듭니다. 물론 HTML을 사용하여 직접 양식을 만들 수도 있지만 더 기능적인 방법이 있습니다. 우리는 Jeffrey Way가 개발한 Illuminatehtml이라는 오픈 소스 라이브러리를 사용합니다. 종속 라이브러리 설치:
<code>composer require illuminate/html</code>
Laravel의 라이브러리를 사용하려면 먼저 laravel에 등록해야 합니다. config/app.php
에서는 laravel에서 제공하는 provider
필드를 볼 수 있는데, 여기에는 laravel의 라이브러리 기능이 설명되어 있습니다. Laravel Framewirk Service Providers...
끝에 새로운 HtmlProvider
<code>'Illuminate\Html\HtmlServiceProvider',</code>
IlluminateHtmlFromFacade
처럼 긴 이름을 소개하기보다는 짧은 이름을 사용하고 싶습니다. 현재 app.php
에서 별칭 섹션을 찾아 끝에 별칭을 추가하세요.
<code>'Form' => 'Illuminate\Html\FormFacade', 'Html' => 'Illuminate\Html\HtmlFacade',</code>
자, 이제 뷰를 만들어 보겠습니다. views/articles/create.blade.php
<code>@extends('layout') @section('content') <h1>Write a New Article</h1> <hr/> {{--使用我们添加的 illuminate\html 开源库--}} {!! Form::open() !!} {!! Form::close() !!} @stop</code>
/articles/create
에 방문하여 오류를 확인하세요. 왜 문제가 발생했는지 테스트해 보겠습니다. 컨트롤러에서 다음과 같이 변경합니다.
<code> public function show($id) { dd('show'); $article = Article::findOrFail($id); return view('articles.show', compact('article')); }</code>
예, 잘 읽으셨습니다. show
메서드에 dd()
메서드를 추가하면 됩니다. 이 메서드는 단순히 메시지를 출력한 다음 종료됩니다. /articles/create
를 다시 방문해보세요. show
출력이 보이나요?
create
에 접속한 이유와 경로가 show
을 제공한 이유는 무엇인가요?
<code>Route::get('articles', 'ArticlesController@index'); Route::get('articles/{id}', 'ArticlesController@show'); Route::get('articles/create', 'ArticlesController@create');</code>
위는 우리의 경로입니다. articles/{id}
는 이것이 와일드카드임을 의미하며 articles/
이후의 모든 항목이 일치한다는 것을 알고 계셨습니까? 우리 /articles/create
도 그와 어울렸어요. 어머나!
해결책은 순서를 조정하는 것입니다.
<code>Route::get('articles', 'ArticlesController@index'); Route::get('articles/create', 'ArticlesController@create'); Route::get('articles/{id}', 'ArticlesController@show');</code>
즉, 특별한 것부터 평범한 것까지, 향후 라우팅 설정에서 이 문제에 항상 주의를 기울여야 합니다. 이제 우리는 articles/create
을 방문하고 있으며 모든 것이 정상입니다.
브라우저에서 소스코드를 확인해보면 method
, action
이 생성될 뿐만 아니라 해커의 위변조 공격을 피하기 위해 서버에서 양식을 검증하면서 숨겨진 _token
필드도 생성되는 것을 확인할 수 있습니다.
뷰를 수정하고 필드를 추가해 보겠습니다.
<code>@extends('layout') @section('content') <h1>Write a New Article</h1> <hr/> {{--使用我们添加的 illuminate\html 开源库--}} {!! Form::open() !!} <div class="form-group"> {!! Form::label('title', 'Title:') !!} {!! Form::text('title', null, ['class' => 'form-control']) !!} </div> <div class="form-group"> {!! Form::label('body', 'Body:') !!} {!! Form::textarea('body', null, ['class' => 'form-control']) !!} </div> <div class="form-group"> {!! Form::submit('Add Article', ['class' => 'btn btn-primary form-control']) !!} </div> {!! Form::close() !!} @stop</code>
폼이 제출되면 실제로는 post
메소드를 사용하여 articles/create
에 제출됩니다. 하지만 RESTful 습관에 따라 post
로 이동하여 폼을 수정해 보겠습니다. 뷰의 메소드에서 제출 경로를 설정합니다. /articles
<code>{!! Form::open(['url' => 'articles']) !!}</code>
<code>Route::post('/articles', 'ArticlesController@store');</code>
<code> //注意:将下面的 use 语句删除,我们使用 facade 接口中的 Request //use App\Http\Requests\Request; //引入下面的命名空间中的 Request use Illuminate\Support\Facades\Request; public function store() { //使用 Illuminate\Html\Request 来返回全部的表单输入字段 $input = Request::all(); //我们直接返回$input,来看一下 return $input; }</code>
필드의 값만 필요한 경우 title
을 사용할 수 있습니다. Request::get('titel')
<code>Article::create($input);</code>
대량 할당을 잊지 않으셨다면,
에서 직접 채울 수 있는 필드를 정의하기 위해 모델에 $fillable
배열을 정의했습니다. create
<code> public function store() { $input = Request::all(); Article::create($input); return redirect('articles'); }</code>
라는 필드도 있습니다. 이를 다루겠습니다. published_at
<code> public function store() { $input = Request::all(); $input['published_at'] = Carbon::now(); Article::create($input); return redirect('articles'); }</code>
또 다른 문제가 있는데, 새로 추가된 것이 전면에 표시되어야 하는데, 다음 컨트롤러를 수정해 보겠습니다.
<code> public function index() { //倒序获取文章 //可以这样 //$articles = Article::orderBy('published_at', 'desc')->get(); //简单方式,当然还有 oldest() $articles = Article::latest('published_at')->get(); return view('articles.index', compact('articles')); }</code>