🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
セキュリティー

このタグは、コンピューターシステムの安全性やデータの機密性に関連したトピックの為に使われます。

Q&A

解決済

1回答

809閲覧

Twitterのような、外部WebサイトからTwitter社のAPIを実行する場合があるケースのCSRF対策

退会済みユーザー

退会済みユーザー

総合スコア0

セキュリティー

このタグは、コンピューターシステムの安全性やデータの機密性に関連したトピックの為に使われます。

0グッド

1クリップ

投稿2020/12/10 07:41

編集2020/12/10 07:41

聞きたいこと

Twitter社は、Tweetボタンを外部サイトに設置することができるようなサービスを提供していると思います。

このようなサービスのAPIのCSRF対策ってどの様になっているのか、自分なりに考えたので合っているかアドバイスいただきたいです。
(もちろんTwitter内部の方でないと正確なところはわかりませんが、、)

確認したい内容

  • CSRF対策としてまず挙がる特定オリジンからのリクエストのみを許可するような設定はしていない
  • → つまりすべてのオリジンからのリクエストはAPIサーバーは受け付ける
  • ユーザーがログインした際に、トークンをAPIサーバーからブラウザにわたし、そのトークンをもとに悪意のあるリクエストか否かをチェックしている

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

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

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

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

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

guest

回答1

0

ベストアンサー

APIでもCSRF対策が必要になる場合がありますが、それはクッキーでセッション維持している場合で、Twitter APIのようにカスタムヘッダ(Authorizationヘッダ等)により認証する場合は、原理的にCSRFの危険はなく、対策も必要ありません。

投稿2020/12/10 09:12

ockeghem

総合スコア11705

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

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

退会済みユーザー

退会済みユーザー

2020/12/11 04:57 編集

なるほど、解答いただきありがとうございます。 > それはクッキーでセッション維持している場合で、 たしかにそうですね。クッキーにセッション情報が保存されていれば、APIへのリクエスト送信時にも自動で気にセッション情報が送信され、悪意のある書き込み等されてしまうということですよね。 追加の質問となってしまうのですが、カスタムヘッダ(Authorizationヘッダ)にて認証する場合、認証トークンのようなものをカスタムヘッダに付与していると思うのですが、そのトークンの保存先ってどこにすべきなのでしょうか。 この質問の追加としてすべきでない質問でしたら、別の質問を作りたいと思います。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問