コンテンツにスキップ

暗号化プロトコル@アプリケーションデータの暗号化技術

はじめに

本サイトにつきまして、以下をご認識のほど宜しくお願いいたします。


01. 暗号化プロトコルの種類と扱われる階層

プロトコルとしての暗号化技術である『暗号化プロトコル』は、赤色で示してある。

encryption_protocol


02. 【アプリケーション層】メールデータの暗号化技術

S/MIME:Secure MIME

▼ S/MINEとは

暗号化ダイジェスト (デジタル署名) を含むデジタル証明書をメールに添付することによって、公開鍵の成りすましを防ぐセキュリティ技術。

S_MIME

▼ S/MIMEにおけるデジタル証明書

デジタル証明書をS/MIMEに使用する場合、特にS/MIME証明書という。


02-02. 【アプリケーション層】リモート通信/操作やファイル転送の暗号化技術

SSH:Secure Shell

▼ SSHとは

ssh_public-key-authentication

公開鍵暗号方式に基づく暗号化プロトコル。

公開鍵暗号方式と、公開鍵認証方式やパスワード認証方式の技術を使用して、インターネットを経由して、サーバーのリモート通信/操作を実行する。

物理webサーバーであっても、webサーバーであっても、SSH公開鍵認証によるリモート通信/操作の仕組みは同じである。

要素 Apache MINA/SSHDの場合 OpenSSHの場合 Puttyの場合 TeraTermの場合
送信元マシン内 - OpenSSH Putty TeraTerm
宛先マシン内 Apache MINA/SSHD OpenSSH - -

▼ SSHポートフォワーディング (SSHポート転送)

ローカルマシンと踏み台サーバーのSSH公開鍵認証と、ポートフォワーディングを組み合わせることによって、外部ネットワークのプライベートネットワーク内リモートサーバーに間接的にパケットを送受信する。

ssh-port-forward

*例*

このリモートサーバーが、仮想環境の場合もあり、ホストと仮想環境の接続でもSSHポートフォワーディングを使用している。

ホスト外部のパソコンから、ホスト上の仮想環境に接続したい場合、SSHポートフォワーディングを使用することによって、ホストを踏み台とした仮想環境への接続が行えるようになる。

docker_port-forwarding


SCP:Secure Copy Protocol

▼ SCPとは

SSHを経由して、ファイル転送を実行する。

SSHの能力をより拡張したプロトコルである。

(1)

クライアントは、リモート通信先のサーバーにファイル送信を命令する。

(2)

サーバーは、Shellを使用してSCPプログラムを起動し、クライアントにファイルを送信する。

SCPの仕組み

▼ ファイルを要求する側に必要なソフトウェア

  • WinSCP
  • Filezilla

▼ ファイルを送信する側に必要なソフトウェア


SFTP:SSH File Transfer Protocol

▼ SFTPとは

SSHを経由して、ファイル転送を実行する。

SSHとFTPを組み合わせたプロトコルではなく、SSHの能力をより拡張したものである。

要素 Filezillaの場合 WinSCPの場合
送信元マシン内 Filezilla WinSCP
宛先マシン内 - -


RDP:Remote Desktop Protocol (リモートデスクトッププロトコル)

▼ リモートデスクトップとは

encryption_protocol_remote-desktop

ゲートウェイマシン上で稼働するリモートデスクトップツールを経由して、異なるネットワーク内のアプリケーションと通信する。

ローカルマシンとリモートにあるアプリケーション間でコピーアンドペーストができない場合がある。

その場合、ローカルマシンのコピーを一度リモート先にあるメモ帳などにペーストし、これを改めてコピーアンドペーストすると良い。

要素 Chromeリモートデスクトップの場合 Guacamoleの場合
送信元マシン内 Chromeリモートデスクトップ -
ゲートウェイマシン内 - Guacamole (guardを含む)
宛先マシン (サーバー、デスクトップPC) 内 - -

▼ 他の暗号化プロトコルとの組み合わせ

ゲートウェイマシンとさえ通信できれば、該当のアプリケーションと通信できてしまうため、ゲートウェイマシン自体へのリクエストでも暗号化プロトコル (例:VPN) を使用した方がよい。

例えば、VPNで許可されたユーザーのみがゲートウェイマシンに通信できるようにしておく。


03. 【トランスポート層】ヘッダー情報の暗号化技術

SSL/TLS:Secure Sockets Layer / Transport Layer Security

▼ SSL/TLSとは

encryption_protocol_ssh-tls

ハイブリッド暗号方式に基づく暗号化プロトコル。

SSL/TLSを使用した通信では、通信の宛先にSSL証明書を設定する必要がある。

トランスポート層で、パケットペイロードのアプリケーションデータの暗号化を担う。

パケットペイロード全体を暗号化したい場合は、IPSecを使用する必要がある。

▼ 相互TLS認証 (mTLS)

トランスポート層で、双方向のピア認証を実施する。

通常のSSL/TLSを使用した通信では、HTTPSリクエストの宛先のみSSL証明書を設定すればよい。

一方で、相互TLS認証ではHTTPSリクエストの送信元にクライアント証明書が必要になる。

mtls

▼ SNI (SSL/TLSの拡張)

宛先のサーバーに複数のSSL証明書を配置できるようになる。

従来のSSL/TLSでは、宛先のサーバーに単一のSSL証明書しか配置できなかった。

仮想ホストを使用してサーバーに複数のドメインを設定していても、SSL証明書は一つになってしまう。

各ドメインを異なるユーザーが使用するようなシステム (例:レンタルサーバー) では、ユーザーのドメインごとにSSL/TLSを分離できない。

L5L7のプロトコルの暗号化

L5L7のプロトコル (例:HTTP、HTTPS、SMTP、DNS、POP3など) を暗号化する。

S』 (例:SMTPS) や『over TLS/SSL』 (例:HTTP over TLS/SSL、SMTP over TLS/SSL) をつけて表記する。

暗号化プロトコルを使用する場合、L6にてL7のアプリケーションデータを暗号化/復号かする。

*例*

Chromeでは、HTTPSプロトコルの使用時にSSL証明書に不備がある (例:自己署名SSL証明書を使用している) と、以下のような警告が表示される。

SSL接続に不備がある場合の警告


04. 【ネットワーク層】ヘッダー情報の暗号化技術

IPsec:Internet Protocol Security

▼ IPSecとは

共通鍵暗号方式に基づく暗号化プロトコル。

ネットワーク層で、パケットペイロード全体の暗号化を担う。

SSL/TLSはアプリケーションデータしか暗号化できないため、より安全である。

例えば、リモートワーク時に、自宅PCと会社のネットワークをVPN接続するために使用される。

VPN接続されると、自宅PCからのTCPスリーウェイハンドシェイクが会社のルーターを通過するため、送信元IPアドレスが会社のものにかわる。

盗聴を防げる。

IPsecによるインターネットVPN

▼ IPsecによるパケットのカプセル化

IPsecによるカプセル化


VPN:Virtual Private Network (仮想プライベートネットワーク)

▼ VPNとは

vpn_between_network

異なるネットワーク間で安全な通信を実行するための仕組み。

異なるネットワーク内の特定のアプリケーションにのみと通信できるリモートデスクトッププロトコルよりも、広範囲に通信できる。

要素 Fortiの場合 OpenVPNの場合 Zscalerの場合
送信元マシン内 FortiClient OpenVpnClient Zapp (クラウドZscalerのクライアントツール)
中継VPNマシン内 FortiGate OpenVpn SDPゲートウェイ (クラウドZscalerのVPNマシン)
宛先マシン内 - - -

▼ アプリケーションデータの暗号化/復号化

リクエスト時、SSL/TLSプロトコルによって通信は暗号化され、接続先のネットワーク内にあるVPNゲートウェイというプロキシサーバーで復号化される。

反対にレスポンス時、VPNゲートウェイで再び暗号化され、クライアントに返信される。

接続先のネットワーク内のサーバがリクエストを受信する時、リクエストのIPアドレスはVPNゲートウェイのものになっている。

SSLによるインターネットVPN

▼ クライアント証明書

SSL/TLSプロトコルで暗号化するために、VPNツール (例:Zscaler) が中間認証局として機能し、署名したクライアント証明書 (おそらくリーフ証明書と呼ぶ) を発行する。

このクライアント証明書をVPNのクライアント側 (例:開発PC) に設定する必要がある。

また、もしクライアント側で仮想環境を作成したい場合、仮想環境がクライアント証明書が信頼できるように、設定する必要がある。

*設定例*

Dockerであればプロキシ設定を実施するか、Dockerfileにルート証明書を組み込む必要がある。

vpn_certificate