お世話になります。
CentOS7系
PHP7.2
MySQL5.7
Cakephp3.6.7
CakephpでAPIを作成しております。
例えば、ユーザーの登録をさせるAPIの場合、
ROOT/api/register をエンドポイントとして
ApiController.php ←
PHP
1== 省略 == 2 /** 3 * User register 4 * 5 * @return $user 6 */ 7 public function register() 8 { 9 // Input : [POST] name, birthday, email, address, gender, password 10 // Output: (json) result for register 11 12 $this->autoRender = false; 13 14 $this->response->getType('application/json'); 15 $this->response->getCharset('UTF-8'); 16 17 if ($this->request->is('post')) { 18 try { 19 $user = $this->Users->newEntity(); 20 $user = $this->Users->patchEntity($user, $this->request->getData()); 21 if ($this->Users->save($user)) { 22 echo json_encode($user); 23 return; 24 } else { 25 $this->response->body(json_encode(false)); 26 return; 27 } 28 } catch (\PDOException $e) { 29 $this->response->body(json_encode(false)); 30 } 31 } 32 $this->response->body(json_encode(false)); 33 return; 34 35 } 36== 省略 ==
これのAPIをPostmanをとおして実行すると、ソースは関係なしに以下のViewがかえってきます。
5000行以上あるので、該当箇所のみ記載します。
PHP
1<h1 class="header-title"> 2Missing CSRF token cookie 3 <span class="header-type">Cake\Http\Exception\InvalidCsrfTokenException</span> 4</h1> 5<span class="stack-frame-file">WWW_ROOT/vendor/cakephp/cakephp/src/Http/Middleware/CsrfProtectionMiddleware.php</span>
『xsrf-token』をヘッダーなどい付与してもうまくいきませんでした。
別のバージョンのCakePHP3系では起こっていなかったのですが、どのように対応をして良いか分かりかねています。
Pご教示いただけると助かります、お願いいたします。
回答1件
あなたの回答
tips
プレビュー