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

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

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

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

PHP

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

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

CSRF

クロスサイトリクエストフォージェリ (Cross site request forgeries、CSRF)は、 外部Webページから、HTTPリクエストによって、 Webサイトの機能の一部が実行されてしまうWWWにおける攻撃手法です。

Ajax

Ajaxとは、Webブラウザ内で搭載されているJavaScriptのHTTP通信機能を使って非同期通信を利用し、インターフェイスの構築などを行う技術の総称です。XMLドキュメントを指定したURLから読み込み、画面描画やユーザの操作などと並行してサーバと非同期に通信するWebアプリケーションを実現することができます。

Q&A

解決済

1回答

727閲覧

WordPressのnonceはなぜ複数必要とされるのか?(CSRF対策のトークンはいつ複数必要なのか?)

massuguda

総合スコア23

WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

PHP

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

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

CSRF

クロスサイトリクエストフォージェリ (Cross site request forgeries、CSRF)は、 外部Webページから、HTTPリクエストによって、 Webサイトの機能の一部が実行されてしまうWWWにおける攻撃手法です。

Ajax

Ajaxとは、Webブラウザ内で搭載されているJavaScriptのHTTP通信機能を使って非同期通信を利用し、インターフェイスの構築などを行う技術の総称です。XMLドキュメントを指定したURLから読み込み、画面描画やユーザの操作などと並行してサーバと非同期に通信するWebアプリケーションを実現することができます。

1グッド

5クリップ

投稿2022/11/08 00:01

前提

WordPressでAjaxを使ったアクションを実装しています

知りたいこと

nonceの理解を深めたいです

特に「なぜ複数必要とされるのか?」が理解できないので教えて頂けませんでしょうか

以下に複数必要との記載があるソースを列挙してまいります

複数必要との記載があるソース1

まず関数リファレンスですが、

一般的に、アクションに対する名前を可能な限りユニークにするのがベストです。
https://wpdocs.osdn.jp/関数リファレンス/wp_create_nonce

とあり、その理由は明記されていません

複数必要との記載があるソース2

そして類似質問がありましたが、

アクション毎に nonce を別々にするのが望ましいです。
https://ja.wordpress.org/support/topic/「nonce」の使い方について/

とあり、やはり理由が不明です

複数必要との記載があるソース3

またはStackoverflowにも質問がありましたが、

Each form should have its own nonce
https://stackoverflow.com/questions/31987963/should-i-use-different-nonces-for-multiple-forms-on-same-page

その理由がここでもわかりません

役割を調べました

複数必要であるというその理由を知るために、公式マニュアルで本来の役割を見てみました

この「Why use a nonce?」の項目を見ると、予想通りnonceがCSRF対策だとわかります

https://codex.wordpress.org/WordPress_Nonces#Why_use_a_nonce.3F

CSRF対策ならば、nonceは「なぜ複数必要とされるのか?」が結局ナゾです。

普通に1つのトークンをフォームに持たせておけば対策は充分に可能だと思うのですが…?

まとめ

疑問は次の点にまとめられると思います

・nonceにはCSRF対策以外の役割があって、そのときに複数必要なのでしょうか?
・それともCSRF対策のトークンが複数必要なケースというのがあるのでしょうか?

宜しくお願い致します

kasumisou👍を押しています

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

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

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

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

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

guest

回答1

0

ベストアンサー

WordPressにはデフォルトでコアのAPIのnonceがあって、APIを利用するにあたってはWordPressが用意しているapiFetchを使っていれば、認証を必要とするような場面においてはnonce発行してヘッダにつけてリクエストを投げてくれるので、CSRF対策はとりあえずされます。
しかし、プラグインの開発などにおいては、WordPressにはいろんな人が作ったいろんなプラグインが他に入っていることも想定して作らないといけません。
nonceが分けられていないと、自分のプラグインが発行したnonceを別のプラグインがこっちが認証するより先に破棄してしまうかもしれません。
あるいは本来許可したくない処理が勝手に許可されるかもしれません。
このような競合をしないために、WordPressにおいてはnonceは必要な処理ごとに発行されるのが望ましいです。

また、自身のプラグインの中であっても、処理ごとにnonceが分けられていれば、本来許可したくない処理ができてしまったりということもしにくく、また個別の処理の終了時にnonceの破棄の処理までセットで行っても、別の処理の認証を誤って止めてしまうというリスクも軽減できます。

投稿2022/11/14 02:51

KazuhiroHatano

総合スコア7804

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問