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

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

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

HTTPS(Hypertext Transfer Protocol Secure)はHypertext Transfer プロトコルとSSL/TLS プロトコルを組み合わせたものです。WebサーバとWebブラウザの間の通信を暗号化させて、通信経路上での盗聴や第三者によるなりすましを防止します。

Apache

Apacheは、Apache HTTP Serverの略で、最も人気の高いWebサーバソフトウェアの一つです。安定性が高いオープンソースソフトウェアとして商用サイトから自宅サーバまで、多くのプラットフォーム向けに開発・配布されています。サーバーソフトウェアの不具合(NCSA httpd)を修正するパッチ(a patch)を集積、一つ独立したソフトウェアとして開発されました。

Q&A

解決済

2回答

514閲覧

Apache SSLヘッダ(SNI)の書き換え

hakoritenshi

総合スコア41

HTTPS

HTTPS(Hypertext Transfer Protocol Secure)はHypertext Transfer プロトコルとSSL/TLS プロトコルを組み合わせたものです。WebサーバとWebブラウザの間の通信を暗号化させて、通信経路上での盗聴や第三者によるなりすましを防止します。

Apache

Apacheは、Apache HTTP Serverの略で、最も人気の高いWebサーバソフトウェアの一つです。安定性が高いオープンソースソフトウェアとして商用サイトから自宅サーバまで、多くのプラットフォーム向けに開発・配布されています。サーバーソフトウェアの不具合(NCSA httpd)を修正するパッチ(a patch)を集積、一つ独立したソフトウェアとして開発されました。

0グッド

0クリップ

投稿2022/08/10 02:30

前提

バージョン:2.4
リバースプロキシとして使用

実現したいこと

SSLヘッダ(SNI)を自由に書き換えて、後段転送する手法はないか。
※HTTPヘッダなら、Headerディレクティブ・RequestHeaderディレクティブで実現可能なことは知っています。

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

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

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

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

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

maisumakun

2022/08/10 02:37

SSLはどこで終端させるのですか?
hakoritenshi

2022/08/10 02:44

いったんApacheで終端させます。 リクエスト⇒★Apache⇒後段サーバ ★ApacheのところでSSLヘッダを書き換えて、後段サーバに転送させる手法を探しています。
maisumakun

2022/08/10 02:55

「ApacheのところでSSLヘッダを書き換えて」とありますが、Apache⇒後段サーバもSSLで通信する、ということでしょうか?
hakoritenshi

2022/08/10 09:32

その通りです。 リクエスト⇒(https)⇒★Apache⇒(https)⇒後段サーバ ★ApacheのところでSSLヘッダを書き換えて、後段サーバに転送させる手法を探しています。
guest

回答2

0

ベストアンサー

SNI のサーバーネームは HTTP の前の TLS の段階で ClientHello で送られます。(HTTP ヘッダではない)
ProxyPass などで https://backend.example.com/ と設定した場合、URL のホスト名 "backend.example.com" が SNI サーバーネームとして送られます。
ホスト名と SNI サーバーネームを違うものにする設定はなさそうです。

また、ProxyPreserveHost On とした場合、Host ヘッダとともに SNI サーバーネームも元のリクエストのものが送られるようです。

投稿2022/08/11 03:06

TaichiYanagiya

総合スコア12146

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

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

0

「SNIヘッダを書き換える」なんてややこしい発想をする必要そのものがないのではないでしょうか。

いったんApacheでSSLを終端してしまう以上、フロントエンド側のSSLとバックエンド側のSSLは全く別個の接続です。Apache内でrewriteなどを行ってバックエンドのサーバへ接続すれば、バックエンドサーバがSNIを適用しているかどうかを問わず、URLやホスト名に応じて適切な接続が構築されます。

投稿2022/08/10 11:05

maisumakun

総合スコア145183

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問