data:image/s3,"s3://crabby-images/341dd/341ddcc736179ff3b7e925f1dc3e154f3b17e655" alt=""
岡田州平の「初心者が知っておくと得をする押さえておくべきlaravelの特徴~第3回:ログイン画面作成とページ遷移~」(Staff Blog)
皆さんこんにちはDHTの岡田です。今回はlaravelを使って、簡単なログイン画面とページ遷移を作成していきたいと思います。今回はModelを使用せず、Route、Controller、Viewを使っていきたいと思います。次回のブログではバリデーションチェックやモデルの使い方を説明しようと思います。
■View
Viewにはhtmlを書いてきます。Resources\views直下にTestLoginRelationフォルダーを作成し、そこにLogin.blade.phpファイルを作成します。
data:image/s3,"s3://crabby-images/efaff/efaff9df29480f205195519b6009c2c1853bb8fa" alt=""
Login.blade.phpに以下のhtmlを記述する。
data:image/s3,"s3://crabby-images/c4986/c498631b876ce7f9d580cab540209f04eab48b9b" alt=""
- formの下に{{csrf_field()}}(Laravel version6以降は@csrfでも可能)は必ず書くようにしてください。LaravelではCSRF対策がされていないフォームの送信は受け付けないようになっているからです。入れていない場合は、以下のようなエラーが出ます。
data:image/s3,"s3://crabby-images/19341/19341d6f551a20bb329dce3aa04d32a94e89471b" alt=""
- action関数は指定するコントローラーアクションに対するURLを作成します。
<a href=”{!!action(‘shinkiTorokuController@ShinkiToroku’)!!}”>新規登録</a>で、新規登録画面に遷移できます(後で説明するRouteの設定は必要です)。
続いて、新規登録画面のViewファイルを作成します。こちらもやり方は同じで、Resources\views\TestLoginRelation配下にShinkiToroku.blade.phpを作成します。
data:image/s3,"s3://crabby-images/24153/241532a4b77b42cc44efbd6194b2e3300d71f156" alt=""
作成後は、以下のhtmlを記述します。
data:image/s3,"s3://crabby-images/539ab/539ab5d4547ea740c65927f00b0e97e41280ac4b" alt=""
form method=”POST”、formaction=”/TestLoginRelation/Login”という形でフォームを用意しています。POST送信された時の処理をRouteに書けば戻るボタンを押下したときに、ログイン画面に戻ります。
■Controller
コントローラーは1から自分で書いて作成することはありません。Artisanコマンドを使って作成します。今回は名前をLoginControllerとします。
data:image/s3,"s3://crabby-images/3c8bc/3c8bcb63514fe959a255207a01be994e652b8210" alt=""
これを実行すると、App\Http\Controllers配下にLoginController.phpが自動で作成されます。
data:image/s3,"s3://crabby-images/1b7eb/1b7ebaa39822f31db5c84f195e1144b35ff6e4fc" alt=""
内容は以下のようにLoginControllerクラスが作成されます。
data:image/s3,"s3://crabby-images/cdd4b/cdd4b1fd57f46a20e0c39f34cd20a93f40a7e9aa" alt=""
では、続いて、LoginControllerクラスに処理を書いていくのですが、今回は渡すものがないので、以下のような簡単なコードになります。
data:image/s3,"s3://crabby-images/963a4/963a4a6c2cfdb933a140fe91a42bcba755d22562" alt=""
続いて、新規登録画面のControllerを作成します。artisanコマンドで、ShinkiTorokuController名で作成しました。
data:image/s3,"s3://crabby-images/82643/826433953d80643b2e717dbf61153b486b8bc619" alt=""
以下のコードを記述します。
data:image/s3,"s3://crabby-images/5b1fd/5b1fdfc3e65e43a3691a9d8cb8b64883128c0b34" alt=""
■Route
Route(ルート)はあるURLにアクセスしたときに、Controllerが処理をするように設定してくれます。WebページにアクセスするためのルーティングはRoutes\web.phpにあります。
data:image/s3,"s3://crabby-images/66bc9/66bc91abfa39a6dd9cb6430465289326aace5899" alt=""
Web.phpに下記のようにコードを記述します。
data:image/s3,"s3://crabby-images/65f2a/65f2ae7792443974a82c2f5083e0e86cc1cfaf4b" alt=""
data:image/s3,"s3://crabby-images/86ef4/86ef481bdba74a1955a1981e3be0b16fc29fef73" alt=""
■結果
・ログインページ
data:image/s3,"s3://crabby-images/2f2dd/2f2dd579d09d7ecb9d6df0db3ad3f91b3463c0a1" alt=""
・新規登録画面
data:image/s3,"s3://crabby-images/36af1/36af10265f2b3560b0c63d79e89e89947f830a5f" alt=""
Controller、View、Routeを使うことで簡単にそして、見やすくログインページを作成することができます。
次回は、バリデーションチェックについて書く予定です。
ぜひ、皆様の勉強の役に立てばと思います。