以下のようにProxyサーバを構築しインターネットアクセスを許可している環境が多いと思いますが、PC-インターネット間通信はほとんどがhttps等のSSL暗号通信(SSL3.0は脆弱性があるため、TLSを使用しているが、便宜上SSL暗号と記載する。)であり、通信の中身がProxyサーバではよめない。このためセキュリティ対策のためにProxyサーバでも通信の中身を読めるようにSSL復号化を検証してみた。
data:image/s3,"s3://crabby-images/877cf/877cfef270e1831f69def36777a738c1b5235770" alt=""
環境構築の概要
今回の環境は以下を使用し構築する。②のWindowsServerはAD、CAを構築するために用意する。検証用ADを作成するため、PCについても普段使用している環境とは別に③を用意する。
data:image/s3,"s3://crabby-images/2493e/2493ed9ed27fa339b37c96b5aee4664ceb6d7a81" alt=""
SSL復号を行うにあたり、証明書の発行は以下2通りの方法で検証を行う。検証2は実際の環境でAD参加PCへの証明書配布が難しい場合に、配布済みのroot証明書を使用して復号化を行うことを想定し検証する。
今回は証明書検証1を実施する。
data:image/s3,"s3://crabby-images/27492/274929d0cf28b02bdb3758bad7d0bc039cc26a7b" alt=""
CentOS 8.4を準備する
ISOファイルをダウンロードする
VirtualBox上にCentOSを準備するため、OVAテンプレートなどを探してみたがなさそうなので、公式からISOファイルをダウンロードする。
以下からISOのx86_64をクリックし、表示されるミラーサイトからISOをダウンロードする。
data:image/s3,"s3://crabby-images/e5798/e57985b8baee6281a97b0f2d336af83246bcc83c" alt=""
VirtualBoxでCentOSを構築する
VirtualBoxを起動し、[新規]を選択し、セットアップウィザードに従い、CentOS用VMを作成する。
data:image/s3,"s3://crabby-images/37c0b/37c0b0cefac87276e40db3765db0cb9d7180854c" alt=""
data:image/s3,"s3://crabby-images/8d575/8d575096e8261355da6c4ed95bfa5ee3250c0380" alt=""
data:image/s3,"s3://crabby-images/418d8/418d89a3ba70d28665ee2a955fe863d43a8355c9" alt=""
data:image/s3,"s3://crabby-images/fc47f/fc47f36658a9eade054e6492aecc2d28b8633582" alt=""
data:image/s3,"s3://crabby-images/7e457/7e457a467ec77cd01282654c7196a00257a5463c" alt=""
VM作成後、光学ドライブにダウンロードしたISOファイルをマウントし、インストールを準備する。
data:image/s3,"s3://crabby-images/31743/3174325b3e5ce5c110af9f2db1b21da5a3f2c475" alt=""
data:image/s3,"s3://crabby-images/a6a76/a6a76e8656379feaac2cb6254d82c7bb633ab2e6" alt=""
VirtualBoXでCentOSのVMを起動しセットアップを行う。
data:image/s3,"s3://crabby-images/100c1/100c158b62d5ed70145d1d08722915568a9ef941" alt=""
data:image/s3,"s3://crabby-images/a4312/a4312e84ea1e4e7644ee5ce7eb8e2267adb001fe" alt=""
data:image/s3,"s3://crabby-images/05ad7/05ad71aa7ccb2f641395ae85ae4376eae7106265" alt=""
Squidをコンパイルする
SSLのデコードを実装するためには、Squidのコンパイル時に‘–enable-ssl-crtd’をつけてコンパイルする必要があります。yumからsquidをインストールする場合、このオプションなしでインストールされてしまうため、コンパイルする必要があります。
yum install gcc gcc-c++ openssl-devel -y
cd /usr/local/src
wget http://www.squid-cache.org/Versions/v4/squid-4.17.tar.gz
tar xf squid-4.17.tar.gz
chown -R root. squid-4.17
cd squid-4.17
./configure --prefix=/usr/local/squid --enable-ssl-crtd --with-openssl --with-default-user=squid
make all
make install
OpenSSLを使用し証明書を作成する
以下コマンドを使用し証明書を作成
cd /usr/local/squid/etc/
openssl req -new -newkey rsa:2048 -sha256 -days 3650 -nodes -x509 -extensions v3_ca -keyout myCA.pem -out myCA.pem
PEMエンコーディングをDERエンコーディングに変更する
openssl x509 -in myCA.pem -outform DER -out myCA.der
chown squid:squid myCA.pem
chmod 400 myCA.pem
squidのコンフィグファイルを編集する。
vi /usr/local/squid/etc/squid.conf
以下squid.confの編集内容
#http_port 3128
http_port 3128 ssl-bump generate-host-certificates=on dynamic_cert_mem_cache_size=16MB cert=/usr/local/squid/etc/myCA.pem
sslcrtd_program /usr/local/squid/libexec/security_file_certgen -s
/usr/local/squid/var/cache/squid/ssl_db -M 16MB
sslcrtd_children 20
sslproxy_cert_error deny all
ssl_bump stare all
SSL証明書発行用データベースを作成
/usr/local/squid/libexec/security_file_certgen -c -s /usr/local/squid/var/cache/squid/ssl_db -M 16MB
chown -R squid:squid /usr/local/squid/var/
FirewallにてTCP3128ポートを許可
firewall-cmd --zone=public --add-port=3128/tcp --permanent
firewall-cmd --reload
squidの起動
/usr/local/squid/sbin/squid
proxyのSSL復号を検証
検証端末に証明書を取り込まずに検証
windows10からProxy(今回構築したsquid)を指定し、Web検索を実施。
以下の通り、squidが使用しているmyCA.pemより作成されたサーバ証明書は、オレオレ証明書だと判断されるため、セキュリティ保護の警告が表示される。
data:image/s3,"s3://crabby-images/43c3e/43c3e1f7d46e6bfbc77478d93fbcc6d905f626de" alt=""
証明書の取り込みあり
OpenSSLにて作成したmyCA.derをルート証明書としてWindows10に取り込む。
取り込んだ後にhttpsにてWebサイトを閲覧しても証明書の警告は発生しない。(以下はwww.bing.comへのhttps接続)
data:image/s3,"s3://crabby-images/53c68/53c68a3ab5e4cec13396ffd2d8d458965e7f21fa" alt=""
このとき、www.bing.comの証明書を確認すると以下の通りとなる。
ルート証明書を取り込んでいるため、以下CAが発行したwww.bing.comの証明書についても証明書チェーンが信頼できるものと判断され、証明書の警告がなくなる。
data:image/s3,"s3://crabby-images/3dc42/3dc42e31a66308acd3c81ab730227070b4bb50de" alt=""
squidのlogを確認しSSLの復号ができているか確認
以下のようにssl復号ができているlogが確認できた。
data:image/s3,"s3://crabby-images/64a79/64a79d016a01c4996b88591d86a581e3a7da90b6" alt=""
参考としたサイト:
data:image/s3,"s3://crabby-images/1e8b9/1e8b9b4779035172f13315167aa5a69f0e6ded22" alt=""
コメント