我已将 nginx 1.4.1 配置为使用自签名证书的 tls/ssl。我只能使用 LAN IP 地址通过 https 进行连接。我也可以连接到server_name
,但只能通过 http 进行连接,并且它只显示“欢迎使用 nginx!”页面。关于如何使用 获得 https 有什么想法吗server_name
?(nginx.conf
只是默认设置。)
$ cat /etc/nginx/sites-available/example.conf
server {
listen 443 ssl;
server_name example.com;
root /srv/web;
ssl_certificate /srv/server.crt;
ssl_certificate_key /srv/server.key;
ssl_protocols SSLv3 TLSv1 TLSv1.1 TLSv1.2;
ssl_ciphers RC4:HIGH:!aNULL:!MD5;
ssl_prefer_server_ciphers on;
access_log /var/log/nginx/access.log;
error_log /var/log/nginx/error.log;
location / {
proxy_set_header X-Forward-For $proxy_add_x_forwarded_for;
proxy_set_header Host $http_host;
proxy_redirect off;
proxy_pass http://127.0.0.1:8000;
}
location ~ /\. {
deny all;
}
}
编辑:我在别人的(免费/公共)子域上会有什么关系吗?我知道要获得由 CA 签名的证书,您需要提供域所有权证明,但在我的用例中这对 nginx 来说应该无关紧要,对吗?
答案1
尝试将 default_server 添加到您显示的服务器节:
server {
listen 443 default_server ssl;
server_name example.com;
root /srv/web;
...
不要忘记重新启动。
答案2
/etc/nginx/sites-enabled
您是否有指向配置文件的符号链接/etc/nginx/sites-available
?
nginx 仅读取 中的配置文件/etc/nginx/sites-enabled
。