BackEnd

LaravelでのCookieファサード利用

投稿日:2021年8月10日 更新日:

はじめに

Webアプリケーション開発ではCookieを利用してブラウザとサーバーで値の共有を行う事があるかと思います。
LaravelのCookieファサードの基本的な利用法を見てみたいと思います。

基本メソッド

付与

任意の場所でCookieファサードの queue メソッドを使用すると設定したい値をキューしておき、レスポンスする際に自動でCookieを付与してくれます。

配列をcookieに保管したい場合もあると思います。その場合は、 json_encode して保管する事が出来ます。

保管した値は、 json_decode して配列として利用出来ます。

取得

Cookieの値をサーバー側で取得する際は、Cookieファサードの get メソッドで取得したいcookieのキー指定する事で取得出来ます。

削除

ブラウザに保存したCookieの値をサーバー側で削除する際は、Cookieファサードの forget メソッドで削除したいcookieのキー指定する事で削除出来ます。

他メソッド

他、Cookieファサードで定義されているメソッドの一部です。

forever

foreverと聞くと無期限のcookieを付与出来そうですが、実際は有効期限5年のものが付与されます

getQueuedCookies

キューしたcookieの一覧を配列で取得します

unqueue

キューからcookieを削除します

ミドルウェア

AddQueuedCookiesToResponse

キューしたcookieのレスポンスへの付与は AddQueuedCookiesToResponse というミドルウェアが行っています。
その為、このミドルウェアを登録しておかないと、キューしてもcookieがレスポンスに付与されません。
Laravelの一部バージョンではデフォルト設定だとルートミドルウェア(web)にしかこのミドルウェアが設定されてないらしく、以前apiルートでいくらキューしてもcookieが付与されず数時間悩んでしまった事がありました。。。

EncryptCookies

通常、付与されたcookieは暗号化されてブラウザに保管されます。
ミドルウェアの EncryptCookies$except にキー名を設定しておくと、値が暗号化されずに保管することが出来ます。

さいごに

Cookieファサードを利用すると簡単にcookie周りの実装を行う事が出来ます。
Laravelで実装するならファサード利用するのが良いかと思います。

おすすめ書籍

PHPフレームワークLaravel Webアプリケーション開発 バージョン8.x対応 1週間で基礎から学ぶLaravel入門 動かして学ぶ!Laravel開発入門

blog-page_footer_336




blog-page_footer_336




-BackEnd
-,

執筆者:


comment

メールアドレスが公開されることはありません。 が付いている欄は必須項目です

CAPTCHA


関連記事

laravel logo

Laravelのブラウザテスト「Dusk」をシンプルなCRUDで始めてみよう

1 はじめに2 Laravel Duskのセットアップ3 新規登録のテスト3.1 テスト対象となるコード3.2 Duskのテストコード3.3 テストの実行4 更新のテスト4.1 テスト対象となるコード ...

rails

Rails5で出力される「alias_method_chain is deprecated.」について

1 はじめに2 alias_method_chainとは3 Module#prependとは4 とりあえず、DEPRECATION WARNINGの出力をなくしたい5 さいごに はじめに 直近のプロジ ...

rails

Railsでの非同期処理とDelayed Job

1 はじめに2 Active Job2.1 Active Jobの役割2.2 ジョブを作成する2.3 ジョブをキューに登録する2.4 コールバック2.5 例外3 Delayed Job3.1 設定3. ...

laravel logo

【Laravel】認証を自作して学ぶguardとmiddleware

1 はじめに1.1 認証処理の仕様2 独自の認証処理の実装2.1 Modelの実装2.2 UserProviderの実装2.3 Guardの実装2.4 Middlewareの実装2.5 Handler ...

rails

Rails 6の変更点と新機能

1 はじめに2 概要3 Rubyのサポートバージョン4 Webpacker4.1 Webpackerの設定4.2 Webpackerでのビルド4.3 ビルドしたJavaScriptファイルを読み込む4 ...

フォロー

blog-page_side_responsive

2021年8月
1234567
891011121314
15161718192021
22232425262728
293031  

アプリ情報

私たちは無料アプリもリリースしています、ぜひご覧ください。 下記のアイコンから無料でダウンロードできます。