[英]Nginx routing on IP address
我有我的域 example.com,所以當有人點擊www.example.com或 example.com 時,請求會自動定向到https://example.com - 工作正常。 但是,當我使用節點應用程序 1.2.3.4 的 IP 地址時,它不會路由到啟用了 SSL 的https://example.com 。 如果我使用 IP 地址,它會顯示相同的頁面,但沒有掛鎖圖標。
那么當有人輸入node app的IP地址時,如何將請求路由到https://example.com呢?
我的 Node JS APP 托管在 AWS EC2 實例上,我還使用 certbot (LetsEncrpyt) 安裝了 ssl。 這是我的 nginx 文件。
events {
worker_connections 4096; ## Default: 1024
}
http {
include conf/mime.types;
include /etc/nginx/proxy.conf;
include /etc/nginx/fastcgi.conf;
index index.html index.htm;
default_type application/octet-stream;
log_format main '$remote_addr - $remote_user [$time_local] $status '
'"$request" $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
access_log logs/access.log main;
sendfile on;
tcp_nopush on;
server_names_hash_bucket_size 128; # this seems to be required for some vhosts
# Settings for normal server listening on port 80
server {
listen 80 default_server;
listen [::]:80 default_server;
server_name example.com www.example.com;
root /usr/share/nginx/html;
# location / {
# }
# Redirect non-https traffic to https
if ($scheme != "https") {
return 301 https://$host$request_uri;
}
}
# Settings for a TLS enabled server.
server {
listen 443 ssl http2 default_server;
listen [::]:443 ssl http2 default_server;
server_name example.com www.example.com;
root /usr/share/nginx/html;
ssl_certificate /etc/letsencrypt/live/example.com/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/example.com/privkey.pem;
ssl_dhparam "/etc/pki/nginx/dhparams.pem";
location / {
proxy_pass http://127.0.0.1:3000;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection 'upgrade';
proxy_set_header Host $host;
proxy_cache_bypass $http_upgrade;
}
}
}
SSL 不適用於 IP,因為證書是為域名頒發的(因此沒有掛鎖圖標)
您可以在端口 80(默認 HTTP 端口)上監聽 IP 並重定向到https://example.com
server {
listen 80;
server_name XXX.XXX.XXX.XXX;
return 301 https://www.example.com$request_uri;
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.