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

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

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

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

nginx

nginixは軽量で高性能なwebサーバーの1つです。BSD-likeライセンスのもとリリースされており、あわせてHTTPサーバ、リバースプロキシ、メールプロキシの機能も備えています。MacOSX、Windows、Linux、上で動作します。

Q&A

解決済

1回答

2181閲覧

サーバの設定ファイルにクライアント証明書のシリアル番号でアクセス制限を掛ける方法について

Clementine

総合スコア157

Apache

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

nginx

nginixは軽量で高性能なwebサーバーの1つです。BSD-likeライセンスのもとリリースされており、あわせてHTTPサーバ、リバースプロキシ、メールプロキシの機能も備えています。MacOSX、Windows、Linux、上で動作します。

0グッド

1クリップ

投稿2020/02/14 06:59

編集2020/02/14 07:11

NGINXの場合、以下の設定でクライアント証明書に登録されているシリアル番号でサーバ側のアクセス制限ができる事がわかりました。

conf

1server { 2 listen 443 ssl http2; 3 server_name www.example.com; 4 root /var/www/html/www.example.com; 5 6 ・・省略 7 8 ssl_verify_client on; 9 ssl_verify_depth 3; 10 ssl_client_certificate /etc/nginx/xxxxxx.crt; 11 12 charset utf-8; 13 resolver 8.8.8.8; 14 location / { 15 if ($ssl_client_serial !~* ^(xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx)$) { 16 return 403; 17 } 18 } 19}

上記の制限をApacheで実現しようと以下のように設定しました

conf

1<VirtualHost *:443> 2 DocumentRoot /var/www/html/www.example.com 3 ServerName www.example.com 4 SSLEngine on 5 6 ・・・省略 7 8 SSLCACertificateFile /etc/httpd/conf.ssl/www.example.com/ca-bundle.crt 9 <Location "/"> 10 SSLVerifyClient require 11 SSLVerifyDepth 3 12 13 // 多分、SERIAL_NUMBER_NAMEに「$ssl_client_serial」に代わる変数(定数?)名が 14  // 入ると思われる 15 SSLRequire %{SERIAL_NUMBER_NAME} in {"SERIAL_NUMBER_VALUE"} 16 17 </Location> 18</VirtualHost>

しかし、SERIAL_NUMBER_NAMEの名称が何になるのか、また上記の構文で間違いないかわからない状態です。

何卒ご教授のほどお願いします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

マニュアル を見ると、%{SSL_CLIENT_M_SERIAL} のようです。

SSLRequire の書式は合っていると思います。
しかし、SSLRequire is deprecated とのことで、替わりにに Require expr を使った方がいいかもしれません。

(例) Require expr "%{SSL_CLIENT_M_SERIAL} in {"シリアル番号"}"

投稿2020/02/14 09:06

TaichiYanagiya

総合スコア12146

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問