生成证书
可以通过以下步骤生成一个简单的证书:
首先,进入你想创建证书和私钥的目录,例如:
1
|
$ cd /usr/local/nginx/conf |
创建服务器私钥,命令会让你输入一个口令:
1
|
$ openssl genrsa -des3 -out server.key 1024 |
创建签名请求的证书(CSR):
1
|
$ openssl req -new -key server.key -out server.csr |
在加载SSL支持的Nginx并使用上述私钥时除去必须的口令:
1
2
|
$ cp server.key server.key.org $ openssl rsa - in server.key.org -out server.key |
启用一个 SSL 虚拟主机
在nginx.conf配置文件中编写:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
server { listen 443; server_name example.com; root /apps/www; index index.html index.htm; ssl on; ssl_certificate /etc/nginx/ssl/nginx.crt; ssl_certificate_key /etc/nginx/ssl/nginx.key; # ssl_protocols SSLv3 TLSv1 TLSv1.1 TLSv1.2; # ssl_ciphers ALL:!ADH:!EXPORT56:RC4+RSA:+HIGH:+MEDIUM:+LOW:+SSLv2:+EXP; # ssl_prefer_server_ciphers on; } |
其中 ssl_certificate 表示 CA 文件,ssl_certificate_key 表示密钥文件。
如果想把 http 请求强制转到 https,可以这样:
1
2
3
4
5
6
|
server { listen 80; server_name example.me; return 301 https://$server_name$request_uri; } |