回答編集履歴

1

回答に具体例追加。

2018/06/25 03:24

投稿

nak
nak

スコア696

test CHANGED
@@ -17,3 +17,161 @@
17
17
  https://readouble.com/laravel/5.5/ja/csrf.html
18
18
 
19
19
  に具体的に記載されておりますので、詳しくはそちらをご覧ください。
20
+
21
+
22
+
23
+
24
+
25
+
26
+
27
+ ---
28
+
29
+ 質問への追記
30
+
31
+ > 下記の方が言うようにCSRF対策をうまくやれば、行けると思うんですがちょっと苦労してます(泣)。
32
+
33
+
34
+
35
+ を受けて。
36
+
37
+
38
+
39
+ すみません、もしかして、こちらの問題、まだ解決されていないのでしょうか?(回答へのコメントを拝見して「わかっていなかったが、回答を見て理解した」という旨かと勘違いしておりました。失礼いたしました)
40
+
41
+
42
+
43
+ 各対応内容について、ご紹介した公式マニュアルの内容をもう少し具体的に記載します。
44
+
45
+ ※両方の対応を行う必要はありません。いずれか1つの対応を実施してください(おススメは「form中にTokenを追加する」のほうです。Laravelで「実施するべし」と定義されているCSRF対策が正しく行える実装なので)。
46
+
47
+
48
+
49
+ なお、以下の記載内容はLaravel5.5のマニュアルを元に記載しています。
50
+
51
+ バージョンが異なる場合、対応方法が異なる場合がありますので、実際に使われているLaravelのバージョン番号をお知らせください。
52
+
53
+
54
+
55
+ ####「form中にTokenを追加する」の場合
56
+
57
+ マニュアルですと、下記の部分に該当します。
58
+
59
+
60
+
61
+ ```
62
+
63
+ アプリケーションでHTMLフォームを定義する場合はいつでも、隠しCSRFトークンフィールドをフォームに埋め込み、CSRF保護ミドルウェアがリクエストの有効性をチェックできるようにしなければなりません。トークン隠しフィールドを生成するには、csrf_fieldヘルパ関数を使ってください。
64
+
65
+
66
+
67
+ <form method="POST" action="/profile">
68
+
69
+ {{ csrf_field() }}
70
+
71
+ ...
72
+
73
+ </form>
74
+
75
+ ```
76
+
77
+
78
+
79
+ 具体的に記載すると、
80
+
81
+ resources\views\helo.php
82
+
83
+
84
+
85
+ `<form method="post" action="/nitta">`
86
+
87
+ のすぐ下に、
88
+
89
+ `<?php echo csrf_field(); ?> `
90
+
91
+ という記述を追加してください(動作未検証)。
92
+
93
+
94
+
95
+
96
+
97
+ ※Bladeテンプレートを使用している場合は、ご紹介したマニュアル内の記載のとおり、
98
+
99
+ `{{ csrf_field() }}`ですが、Bladeテンプレートを使用しない場合は中かっこを使った関数呼び出し(例:`{{ hoge() }}` )ができません。
100
+
101
+ そのため、 `<?php echo hoge(); ?>` で関数を呼び出します。
102
+
103
+
104
+
105
+
106
+
107
+ ####「MiddleWareでCSRF対策を無効にする設定を行う」の場合
108
+
109
+ マニュアルですと、「URIの除外」項全体が該当します。
110
+
111
+
112
+
113
+ 具体的には、ご自身の
114
+
115
+
116
+
117
+ app\Http\Middleware
118
+
119
+ ディレクトリ(無かったら作成してください)の中に
120
+
121
+ VerifyCsrfToken.php
122
+
123
+ というファイルを作っていただき、その中に、下記の内容を記載してください。
124
+
125
+
126
+
127
+ ```php
128
+
129
+ <?php
130
+
131
+
132
+
133
+ namespace App\Http\Middleware;
134
+
135
+
136
+
137
+ use Illuminate\Foundation\Http\Middleware\VerifyCsrfToken as Middleware;
138
+
139
+
140
+
141
+ class VerifyCsrfToken extends Middleware
142
+
143
+ {
144
+
145
+ /**
146
+
147
+ * CSRFバリデーションから除外するURI
148
+
149
+ *
150
+
151
+ * @var array
152
+
153
+ */
154
+
155
+ protected $except = [
156
+
157
+ 'nitta',
158
+
159
+ 'http://(実際のドメイン)/nitta', // おそらく不要定義です('nitta'だけでうまくいくなら削除してください)
160
+
161
+ ];
162
+
163
+ }
164
+
165
+ ```
166
+
167
+
168
+
169
+
170
+
171
+ 追伸:
172
+
173
+ みなさんがおっしゃっている「blade」というのは、こちらのことです。
174
+
175
+ https://readouble.com/laravel/5.5/ja/blade.html
176
+
177
+ ご参考まで。