SSLと安全な暗号を使用してNginxを利用したWebサイトを保護する方法

前書き

SSL(Secure Sockets Layerの略)とその後継であるTLS(Transport Layer Securityの略)は、インターネット上の通信を保護するための暗号化プロトコルです。Webサイトへの安全な接続を作成するために使用できます。

はじめに

NginxとOpenSSLがサーバーにインストールされていることを確認します。この記事では、自己署名SSL証明書を生成することによってプロセスを示します。

手順1:証明書と秘密キーのディレクトリを作成する

/ etc / nginx内にディレクトリを作成(および入力)します(そのディレクトリがNginxの構成ディレクトリであると想定)。

sudo mkdir /etc/nginx/ssl
cd /etc/nginx/ssl # we'll perform our next few steps in this dir

ステップ2:秘密鍵とCSRを作成する

まず、サイトの秘密鍵を作成します。この例では、セキュリティを強化するために4096ビットのキーを使用します。2048ビットも安全ですが、1024ビットの秘密鍵は使用しないでください。

sudo openssl genrsa -out example.com.key 4096

次に、証明書に署名するための証明書署名要求(CSR)を作成します。512ビットのSHA-2を使用します。-sha512オプションに注意してください。

sudo openssl req -new -key example.com.key -out example.com.csr -sha512

入力が必要なフィールドのリストが表示Common Nameされます。ドメイン名が設定されていることを確認してください!また、空白のままにA challenge passwordAn optional company nameます。

You are about to be asked to enter information that will be incorporated
into your certificate request.
What you are about to enter is what is called a Distinguished Name or a DN.
There are quite a few fields but you can leave some blank
For some fields there will be a default value,
If you enter '.', the field will be left blank.
-----
Country Name (2 letter code) [AU]:US
State or Province Name (full name) [Some-State]:CA
Locality Name (eg, city) []:LosAngeles
Organization Name (eg, company) [Internet Widgits Pty Ltd]:Example Inc
Organizational Unit Name (eg, section) []:Security
Common Name (e.g. server FQDN or YOUR name) []:*.example.com
Email Address []:[email protected]

Please enter the following 'extra' attributes
to be sent with your certificate request
A challenge password []:
An optional company name []:

ステップ3:証明書に署名する

ほぼ完了しました!署名するだけです。365(365日後に期限切れ)を希望する日数に置き換えることを忘れないでください。

sudo openssl x509 -req -days 365 -in example.com.csr -signkey example.com.key -out example.com.crt -sha512

これで、自己署名証明書の作成が完了しました。

ステップ4:セットアップ

NginxのサンプルSSL構成ファイルを開きます。

sudo nano /etc/nginx/conf.d/example_ssl.conf

HTTPS Serverという行の下のセクション内のコメントを外します。設定を以下の情報と一致させexample.comserver_name行のをドメイン名またはIPアドレスに置き換えます。また、ルートディレクトリを設定します。

# HTTPS server

server {
    listen       443 ssl;
    server_name example.com;

    ssl_certificate /etc/nginx/ssl/example.com.crt;
    ssl_certificate_key /etc/nginx/ssl/example.com.key;
    ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
    ssl_prefer_server_ciphers on;
    ssl_ecdh_curve secp384r1;
    ssl_ciphers ECDHE-RSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-SHA384:DHE-RSA-AES256-GCM-SHA384:DHE-RSA-AES256-SHA256:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-SHA256:DHE-RSA-AES128-SHA256:ECDHE-RSA-AES256-SHA:!aNULL:!eNULL:!EXPORT:!DES:!3DES:!MD5:!PSK:!RC4; # no RC4 and known insecure cipher
location / {
  root   /usr/share/nginx/html;
  index  index.html index.htm;
 }
}

次に、Nginxを再起動します。

service nginx restart

次に、httpsアドレス(https://your.address.tld)を使用してWebサイトにアクセスします。Webブラウザーに、自己署名証明書を使用した安全な接続が表示されます。



Leave a Comment

CentOS 7にApacheをインストールする方法

CentOS 7にApacheをインストールする方法

CentOS 7サーバーにApache 2.4をインストールする方法を説明します。安定したウェブサーバーを構築するための前提条件と手順を解説します。

FreeBSD 11.1にBlacklistdをインストールする方法

FreeBSD 11.1にBlacklistdをインストールする方法

FreeBSD 11.1におけるBlacklistdのインストール方法について詳しく解説します。この方法を通じて、強力なセキュリティ対策を実装できます。

Windows Serverのサーバーマネージャーを使用した複数サーバーの管理

Windows Serverのサーバーマネージャーを使用した複数サーバーの管理

サーバーマネージャーを使用して、Windows Serverの管理が向上します。セキュリティリスクを軽減し、効率的な管理を実現します。

CentOS 7にSeafileサーバーをインストールする方法

CentOS 7にSeafileサーバーをインストールする方法

CentOS 7にSeafileサーバーをインストールする方法。Seafile(コミュニティバージョン)は、ownCloudに似た無料のオープンソースファイル同期および共有ソリューションです。

DebianでSnortを設定する方法

DebianでSnortを設定する方法

Snortは無料のネットワーク侵入検知システムです。最新の方法で、SnortをDebianにインストールし、設定する手順を紹介します。ネットワークのセキュリティを強化しましょう。

CentOS 7にGraylogサーバーをインストールする方法

CentOS 7にGraylogサーバーをインストールする方法

CentOS 7にGraylogサーバーをインストールし、ログ管理を行う方法を学びます。

WindowsでhMailServerを使用してメールサーバーを構築する

WindowsでhMailServerを使用してメールサーバーを構築する

WindowsサーバーでWebサイトを実行している場合、電子メールも受信できるようにするためにhMailServerを使用する方法を解説します。

Ubuntu 19.04にFiveMサーバーをインストールする方法

Ubuntu 19.04にFiveMサーバーをインストールする方法

FiveMサーバーをUbuntu 19.04にインストールするための詳細なガイド。必要条件からインストール、起動、トラブルシューティングまで、すべてのステップを含みます。

WsgiDAVを使用してDebian 10にWebDAVをデプロイする

WsgiDAVを使用してDebian 10にWebDAVをデプロイする

Debian 10にWebDAVをデプロイする方法を学び、WsgiDAVとSSL証明書で安全な接続を実現しましょう。

ヘルスケア2021における人工知能の影響

ヘルスケア2021における人工知能の影響

ヘルスケアにおけるAIは、過去数十年から大きな飛躍を遂げました。したがって、ヘルスケアにおけるAIの未来は、日々成長を続けています。