有时候,我们网站,需要将顶级域名xxx.com统一跳转到二级域名www.xxx.com下。这时候,我们可以通过修改nginx配置达到我们的目的。
#以下属性中,以ssl开头的属性表示与证书配置有关。
server {
listen 443 ssl;
#配置HTTPS的默认访问端口为443。
#如果未在此处配置HTTPS的默认访问端口,可能会造成Nginx无法启动。
#如果您使用Nginx 1.15.0及以上版本,请使用listen 443 ssl代替listen 443和ssl on。
server_name www.xxx.com;
#需要将yourdomain替换成证书绑定的域名。
ssl_certificate /opt/certs/www.xxx.com.pem;
#需要将cert-file-name.pem替换成已上传的证书文件的名称。
ssl_certificate_key /opt/certs/www.xxx.com.key;
#需要将cert-file-name.key替换成已上传的证书私钥文件的名称。
ssl_session_timeout 5m;
ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
#表示使用的加密套件的类型。
ssl_protocols TLSv1.1 TLSv1.2 TLSv1.3;
#表示使用的TLS协议的类型。
ssl_prefer_server_ciphers on;
# 设置代理服务器(nginx)保存用户头信息的缓冲区大小
proxy_buffer_size 8k;
location / {
# 主要是在这里进行判断,进行301重定向操作
if ($host= "xxx.com") {
return 301 https://www.xxx.com$request_uri;
}
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header REMOTE-HOST $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://backend;
}
}
server {
listen 80;
server_name www.xxx.com
#charset koi8-r;
#access_log logs/host.access.log main;
rewrite ^(.*) https://$server_name$1 permanent;#80端口请求都强制跳转到443端口进行处理
charset utf-8;
}
修改完nginx配置,记得需要重启一下,方可生效。