OpenWrt化WZR-HP-G300NHのLuCIをssl(https)で接続するよう設定する
「システム・ソフトウェア」を選択し、「リストの更新」を行う
data:image/s3,"s3://crabby-images/4c531/4c531be6fc157f58e485a663544d18d2e887ec3d" alt=""
プログレッシブ表示が無いので「リストの更新」状況が判らないが結果表示されるまで待つ。
data:image/s3,"s3://crabby-images/5f457/5f4579a0d7b6f7e718cec73d7559962ab90a13ad" alt=""
「フィルタ」に「luci-ssl」設定し検索する
data:image/s3,"s3://crabby-images/f22da/f22da5c46f2ef452e61d558187c2547d26bde3ca" alt=""
「luci-ssl」をインストールする
data:image/s3,"s3://crabby-images/9b865/9b865d9b666c5171eb5835f7eec56f6b75b4bf31" alt=""
パッケージがダウンロードされ、インストールが行われる
data:image/s3,"s3://crabby-images/237b1/237b12194c413983a1f68aac1242873c7cd6002c" alt=""
インストールが終了すると「再起動」確認となるので、再起動を実行する
data:image/s3,"s3://crabby-images/055b5/055b59fefa4977d7778cdf38264079f369dc9a06" alt=""
いくら待っても再接続しないので、ほど良い頃合いを見計らって、「http://OpenWrt/index.html」でアクセスする
data:image/s3,"s3://crabby-images/5fe1f/5fe1ffef65fc19d1ed415aa0ba2204925642fac8" alt=""
「luci-sslパッケージ」に含まれる「px5g」により自己署名サーバ証明書が生成され起動されたhttpsにredirectで接続する
data:image/s3,"s3://crabby-images/18939/18939d78dc437e3200ba110d7446248fd0256399" alt=""
「サーバ証明書の内容」
data:image/s3,"s3://crabby-images/5607c/5607c9ba3eb095ddbb8aa7bba2fec7bfb441e1d0" alt=""
証明書を信頼して接続を続行する
data:image/s3,"s3://crabby-images/b4c7b/b4c7b14ccfb37cb357dbd9da5a777e8100bf0a66" alt=""
macOSX sierraのキーチェーンに自己署名証明書を登録するための認証を行う
data:image/s3,"s3://crabby-images/9d7c8/9d7c85b5e446638e70a38ee82fbb21dbc0cfb401" alt=""
キーチェーンのログインにサーバ証明書が登録される(正規のサーバ証明書設定後は、削除する)
data:image/s3,"s3://crabby-images/0cfda/0cfdae203bb6943c0b78d1bb5383d7c5ee693b00" alt=""
httpsでLuCI起動後、メニューを確認するが、httpsに関連した設定は存在しない。
data:image/s3,"s3://crabby-images/592d6/592d65e141064ce5bc6f065fae8efea97d889f40" alt=""
サーバ証明書をプライベートCAが発行したイントラネット用サーバ証明書に入れ替える方法を調べてみる
・安全性の向上について(WebUI)
・利用できるhttpパッケージ
・uhttpdサーバを使用
・サーバ証明書の設定
「luci-ssl」パッケージは、uhttpdサーバでサーバ証明書(公開鍵)が「/etc/uhttpd.crt」に秘密鍵が「/etc/uhttpd.key」に設定されている。uhttpd.crtもuhttpd.keyもDERフォーマットのバイナリである必要がある。CA発行の中間CA証明書やルート証明書は、結合して「/etc/uhttpd.crt」に設定するよう記載されている。
Let's Encryptの証明書(DST Root CA X3/Let's Encrypt Authority X3/サーバ証明書)のようにtrust pathに中間CAがあるサーバ証明書をOpenWrtに設定させる時の情報
・https configuration for uhttpd
・DER Certificate chain not being walked, FireFox and SSL Labs fail
これらの情報を解釈すると「trust path」の公開鍵を結合したファイルを公開鍵設定する。
結合したファイルは、上記情報によると「結合したファイル」を「バイナリ(der)」変換するように読める。
「openssl x509」のコマンドで結合したファイルをバイナリにすることは出来ない(実行した場合は、ファイル先頭の証明書がDERファイルとなる)。
結合する「trust path」の各証明書は、PEMフォーマット。結合したfullpathファイルもPEMフォーマット。
ファイルの拡張子は、「.pem」でも「.crt」でも良い。
「/etc/config/uhttpd」設定ファイルで「option cert ファイルパス名」で指定されたファイル。
秘密鍵
・暗号化されていない「バイナリ形式(DER)」のファイルである事が必要。
・秘密鍵を「PEM形式」のファイルを指定するとuhttpdが起動しない。
サーバ証明書の「PEM -> DER」変換
server.pem -> server.crt
openssl x509 -in server.pem -outform der -out server.crt
サーバ証明書の「DER -> PEM」変換
server.crt -> server.pem
openssl x509 -inform der -in server.crt -out server.pem
trust pathの結合
cp server.pem intermediate-ca.pem > fullpath.pem
サーバ秘密鍵の「PEM -> DER」変換
openssl rsa -in server-key.pem -outform der -out server.key
証明書ファイルをOpenWrtにコピー
scp fullpath.pem root@192.168.1.1:/etc/uhttpd.crt
scp server.key root@192.168.1.1:/etc/uhttpd.key
OpenWrtのuhttpd設定例
/etc/config/uhttpd
option cert /etc/uhttpd.crt
option key /etc/uhttpd.key
OpenWrtのuhttpd再起動
/etc/init.d/uhttpd restart
OpenWrtがSSLネゴシエーション時に「trust path」設定のサーバ証明書が提示されるか確認する
openssl s_client -connection 192.168.1.1:443 -CAfile rootCA.pem -showcerts -status
data:image/s3,"s3://crabby-images/70f0e/70f0ed241f427821e474101c2b8a834bfe485ca5" alt=""
「システム・ソフトウェア」を選択し、「リストの更新」を行う
data:image/s3,"s3://crabby-images/4c531/4c531be6fc157f58e485a663544d18d2e887ec3d" alt=""
プログレッシブ表示が無いので「リストの更新」状況が判らないが結果表示されるまで待つ。
data:image/s3,"s3://crabby-images/5f457/5f4579a0d7b6f7e718cec73d7559962ab90a13ad" alt=""
「フィルタ」に「luci-ssl」設定し検索する
data:image/s3,"s3://crabby-images/f22da/f22da5c46f2ef452e61d558187c2547d26bde3ca" alt=""
「luci-ssl」をインストールする
data:image/s3,"s3://crabby-images/9b865/9b865d9b666c5171eb5835f7eec56f6b75b4bf31" alt=""
パッケージがダウンロードされ、インストールが行われる
data:image/s3,"s3://crabby-images/237b1/237b12194c413983a1f68aac1242873c7cd6002c" alt=""
インストールが終了すると「再起動」確認となるので、再起動を実行する
data:image/s3,"s3://crabby-images/055b5/055b59fefa4977d7778cdf38264079f369dc9a06" alt=""
いくら待っても再接続しないので、ほど良い頃合いを見計らって、「http://OpenWrt/index.html」でアクセスする
data:image/s3,"s3://crabby-images/5fe1f/5fe1ffef65fc19d1ed415aa0ba2204925642fac8" alt=""
「luci-sslパッケージ」に含まれる「px5g」により自己署名サーバ証明書が生成され起動されたhttpsにredirectで接続する
data:image/s3,"s3://crabby-images/18939/18939d78dc437e3200ba110d7446248fd0256399" alt=""
「サーバ証明書の内容」
data:image/s3,"s3://crabby-images/5607c/5607c9ba3eb095ddbb8aa7bba2fec7bfb441e1d0" alt=""
証明書を信頼して接続を続行する
data:image/s3,"s3://crabby-images/b4c7b/b4c7b14ccfb37cb357dbd9da5a777e8100bf0a66" alt=""
macOSX sierraのキーチェーンに自己署名証明書を登録するための認証を行う
data:image/s3,"s3://crabby-images/9d7c8/9d7c85b5e446638e70a38ee82fbb21dbc0cfb401" alt=""
キーチェーンのログインにサーバ証明書が登録される(正規のサーバ証明書設定後は、削除する)
data:image/s3,"s3://crabby-images/0cfda/0cfdae203bb6943c0b78d1bb5383d7c5ee693b00" alt=""
httpsでLuCI起動後、メニューを確認するが、httpsに関連した設定は存在しない。
data:image/s3,"s3://crabby-images/592d6/592d65e141064ce5bc6f065fae8efea97d889f40" alt=""
サーバ証明書をプライベートCAが発行したイントラネット用サーバ証明書に入れ替える方法を調べてみる
・安全性の向上について(WebUI)
・利用できるhttpパッケージ
・uhttpdサーバを使用
・サーバ証明書の設定
「luci-ssl」パッケージは、uhttpdサーバでサーバ証明書(公開鍵)が「/etc/uhttpd.crt」に秘密鍵が「/etc/uhttpd.key」に設定されている。uhttpd.crtもuhttpd.keyもDERフォーマットのバイナリである必要がある。CA発行の中間CA証明書やルート証明書は、結合して「/etc/uhttpd.crt」に設定するよう記載されている。
Let's Encryptの証明書(DST Root CA X3/Let's Encrypt Authority X3/サーバ証明書)のようにtrust pathに中間CAがあるサーバ証明書をOpenWrtに設定させる時の情報
・https configuration for uhttpd
・DER Certificate chain not being walked, FireFox and SSL Labs fail
これらの情報を解釈すると「trust path」の公開鍵を結合したファイルを公開鍵設定する。
結合したファイルは、上記情報によると「結合したファイル」を「バイナリ(der)」変換するように読める。
「openssl x509」のコマンドで結合したファイルをバイナリにすることは出来ない(実行した場合は、ファイル先頭の証明書がDERファイルとなる)。
結合する「trust path」の各証明書は、PEMフォーマット。結合したfullpathファイルもPEMフォーマット。
ファイルの拡張子は、「.pem」でも「.crt」でも良い。
「/etc/config/uhttpd」設定ファイルで「option cert ファイルパス名」で指定されたファイル。
秘密鍵
・暗号化されていない「バイナリ形式(DER)」のファイルである事が必要。
・秘密鍵を「PEM形式」のファイルを指定するとuhttpdが起動しない。
サーバ証明書の「PEM -> DER」変換
server.pem -> server.crt
openssl x509 -in server.pem -outform der -out server.crt
サーバ証明書の「DER -> PEM」変換
server.crt -> server.pem
openssl x509 -inform der -in server.crt -out server.pem
trust pathの結合
cp server.pem intermediate-ca.pem > fullpath.pem
サーバ秘密鍵の「PEM -> DER」変換
openssl rsa -in server-key.pem -outform der -out server.key
証明書ファイルをOpenWrtにコピー
scp fullpath.pem root@192.168.1.1:/etc/uhttpd.crt
scp server.key root@192.168.1.1:/etc/uhttpd.key
OpenWrtのuhttpd設定例
/etc/config/uhttpd
option cert /etc/uhttpd.crt
option key /etc/uhttpd.key
OpenWrtのuhttpd再起動
/etc/init.d/uhttpd restart
OpenWrtがSSLネゴシエーション時に「trust path」設定のサーバ証明書が提示されるか確認する
openssl s_client -connection 192.168.1.1:443 -CAfile rootCA.pem -showcerts -status
data:image/s3,"s3://crabby-images/70f0e/70f0ed241f427821e474101c2b8a834bfe485ca5" alt=""