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

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

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

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails 4

Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。

Q&A

解決済

2回答

2418閲覧

リダイレクト先のドメインを取得する方法

hn1

総合スコア303

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails 4

Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。

0グッド

0クリップ

投稿2016/12/21 03:47

###前提・実現したいこと
redirect_toでリダイレクトされるドメインを取得する方法はあるでしょうか。
例えば「redirect_to '/path'」としてリダイレクトを行なった場合、
リクエストヘッダのHostやRefererのドメインがLocationヘッダに反映されてリダイレクト先のドメインになると思います。
仮にHostやRefererが改ざんされた場合、予期しないドメインにリダイレクトされてしまうことを懸念しており、
リダイレクト先のドメインが正しいかどうかのチェックを入れたいと考えております。

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

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

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

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

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

guest

回答2

0

ベストアンサー

リクエストヘッダのHostやRefererのドメインがLocationヘッダに反映されてリダイレクト先のドメインになると思います。

特に設定しなかった場合、元のHost:ドメインでリダイレクトを返しますが、そもそもHTTP/1.1でhttp://www.example.com/foo/barにアクセスしようとした場合、HTTPのリクエストは以下のようになります。

GET /foo/bar HTTP/1.1 Host: www.example.com (後略)

ということで、「Hostを偽装した場合」はそもそもつながりません。逆に、「Railsまでアクセスが来た」ということであればそのHostでアクセスできているということになります。

どうしても特定のドメインに固定したいなら、Rails.application.routes.default_url_options[:host]に指定するという方法もあります。

投稿2016/12/21 07:02

maisumakun

総合スコア145184

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

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

hn1

2016/12/21 23:27

ありがとうございます。 勉強になりました。
guest

0

質問内容については未解決ですが、
リクエストヘッダのHostやRefererをチェックすることで対応しました。

投稿2016/12/21 05:40

hn1

総合スコア303

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問