質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

解決済

1回答

458閲覧

【Laravel】viewのform内で@csrfをechoしたい

Ochi_a

総合スコア2

Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

0クリップ

投稿2022/05/23 09:05

前提

view内でforeachしながらechoでformを作成する処理を実装中です。
echoによってフォームを作成する場合の、@csrfの記述法が分からず、エラー(419 PAGE EXPIRED)が表示されてしまいます。

実現したいこと

foreachの中でechoによってフォームを作成したい。

該当のソースコード

php

1foreach($logs as $log) { 2 $date = $log->search_date; 3 echo '<form method="post" action="'."detail".'">'; 4   echo '@csrf'; 5 echo '<input type="hidden" name="log_date" value="'.$date.'">'; 6 echo '<input type="submit" value="詳細">'; 7 echo "</form>"; 8}

上記のコードでは@csrfがそのまま文字列としてviewに出力されてしまい、フォームから遷移先に移動する際に419エラー発生がしてしまいます。
echoでformを作成する際の、@csrfの正しい記述法についてお教えいただければ幸いです。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2022/05/23 09:34 編集

Laravelのバージョンも示してください。bladeテンプレート内にただ「@csrf」って書くだけなのですが。phpコードで出力しないでくださいね。
Ochi_a

2022/05/23 09:38

laravelのバージョンは9.12.2です。 blade内にそのまま@csrfを記述した場合、Undefined constant "csrf"となってしまいます。 質問文内に記述したコードが実際にbladeに記述しているコードです。
Ochi_a

2022/05/23 09:53

プログラミング自体まったくの初心者ですので、ミドルウェアについてまだ何も分からず... 今回はsPyRRKV5VGqm5TF様にご提示いただいた内容で解決しましたが、ミドルウェアについても学習させていただきます。 ご回答ありがとうございます。
guest

回答1

0

ベストアンサー

もしかして、bladeテンプレート上で

php

1<input type="hidden" name="_token" value="{{ csrf_token() }}">

って書くこともできるから、逆にphpコードでは

php

1<?php 2// ~ 3echo '<input type="hidden" name="_token" value="' . csrf_token() . '">';

でできちゃったりする?(やったことはない)

投稿2022/05/23 09:42

退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Ochi_a

2022/05/23 09:50

ご回答ありがとうございます。 ご提示いただいた内容で解決することができました。 誠にありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問