Calvert's murmur

為 Ngnix 建立自行簽章的憑證

2013-10-17

約 2382 字 / 需 13 分鐘閱讀

必要條件

產生憑證需要 OpenSSL 類別庫,請先確認系統是否已安裝 OpenSSL。

若尚未安裝,可透過以下方式安裝:

  • Mac OS X 使用 Homebrew 安裝

    $ brew install openssl
  • Windows 可到此網站下載安裝檔:OpenSSL for Windows

  • Ubuntu/Debian Linux

    $ sudo apt-get install openssl
  • RedHat/CentOS Linux

    $ sudo yum install openssl

步驟一:建立存放憑證的資料夾

$ mkdir /etc/nginx/ssl
$ cd /etc/nginx/ssl

步驟二:建立伺服器私鑰及憑證

建立伺服器私鑰

開始建立伺服器私鑰。過程中,將會提示輸入密碼,請牢記此密碼,若忘記或遺失該密碼,將無法存取憑證。

$ sudo openssl genrsa -des3 -out server.key 2048

以下為建立私鑰時可能會看到的訊息

Generating RSA private key, 2048 bit long modulus
....................+++
..............................................................+++
e is 65537 (0x10001)
Enter pass phrase for server.key:
Verifying - Enter pass phrase for server.key:
建立伺服器憑證

建立時會詢問私鑰密碼,若密碼不正確便無法建立憑證。
建立憑證時,最重要的欄位為 Common Name。請在此輸入網域名稱,若沒有網域名稱則輸入網站 IP。並請不要填寫 challenge password 及 optional company name 欄位。

$ sudo openssl req -new -key server.key -out server.csr

以下為建立憑證時可能會看到的訊息

Enter pass phrase for server.key:
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]: TW
State or Province Name (full name) [Some-State]: Taipei
Locality Name (eg, city) []: Taipei
Organization Name (eg, company) [Internet Widgits Pty Ltd]: Example Inc
Organizational Unit Name (eg, section) []:
Common Name (e.g. server FQDN or YOUR name) []: example.com
Email Address []: admin@example.com

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

步驟三:移除伺服器私鑰密碼(Passphrase)

雖然密碼可提供高度的安全性,但若有人重載 nginx 則會產生問題。在 nginx 崩潰或需要重新啟動時,永遠都需要輸入密碼才能使網頁伺服器上線。

$ sudo cp server.key server.key.origin
$ sudo openssl rsa -in server.key.org -out server.key

步驟四:為憑證簽章

可以自行指定該憑證有效期限,在此範例中憑證為 1 年後到期。

$ sudo openssl x509 -req -days 365 -in server.csr -signkey server.key -out server.crt

現在所需的憑證已產生完畢!

步驟五:設定憑證

開啟 nginx 設定檔,加入以下設定,請記得將 server_name 改為網域名稱或 IP。

# HTTPS server

server {
    listen       443;
    server_name example.com;

    ssl on;
    ssl_certificate /etc/nginx/ssl/server.crt;
    ssl_certificate_key /etc/nginx/ssl/server.key;
}

重新啟動 nginx

$ sudo /etc/init.d/nginx restart

前往 https://domain_name 將會看到自行簽章的憑證。