nginx僞靜态規則将80端口不帶www的域名全部跳轉到帶https的www域名

nginx僞靜态規則将80端口不帶www的域名全部跳轉到帶https的www域名

遇到一個很久都無法解決的問題,就是我的網站在開啓證書後,想把80端口的域名、不帶www的域名全部301跳轉到帶SSL證書的www域名,看我下面的例子:

http://dobunkan.com    301  到   https://www.sobuer.com

http://www.dobunkan.com    301  到   https://www.sobuer.com

https://dobunkan.com    301  到   https://www.sobuer.com

看起來很簡單的問題,但是解決起來非常麻煩,因爲nginx重寫規則不支持 if(條件1 || 條件2),今天想到了一個很笨的解決辦法,思路是這樣的,把80端口、443端口的頂級域名、443端口的長域名分開寫,這樣就達到目的了,請看我的例子:

server {
    listen 80;
    server_name www.dobunkan.com dobunkan.com;
    rewrite ^(.*)$ https://www.sobuer.com$1 permanent;
}
server {
    listen 443 ssl;
    ssl_certificate    /www/host/domAIn/vhost/cert/domain.dobunkan.com/fullchain.pem;
    ssl_certificate_key    /www/host/domain/vhost/cert/domain.dobunkan.com/privkey.pem;
    server_name dobunkan.com;
    return 301 https://www.sobuer.com$request_uri;
}
server {
    listen 443 ssl;
    index index.php index.html index.htm default.php default.htm default.html;
    root /www/wwwroot/domain.dobunkan.com/public_html;
    ssl_certificate    /www/host/domain/vhost/cert/domain.dobunkan.com/fullchain.pem;
    ssl_certificate_key    /www/host/domain/vhost/cert/domain.dobunkan.com/privkey.pem;
    ssl_protocols TLSv1 TLSv1.1 TLSv1.2 TLSv1.3;
    ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:HIGH:!aNULL:!MD5:!RC4:!DHE;
    ssl_prefer_server_ciphers on;
    ssl_session_cache shared:SSL:10m;
    ssl_session_timeout 10m;
    error_page 497  https://$host$request_uri;
    server_name  www.dobunkan.com;
	
	
    #SSL-END
    
    #ERROR-PAGE-START  錯誤頁配置,可以注釋、删除或修改
    #error_page 404 /404.html;
    #error_page 502 /502.html;
    #ERROR-PAGE-END
    
    #PHP-INFO-START  PHP引用配置,可以注釋或修改
    include enable-php-73.conf;
    #PHP-INFO-END
    
    #REWRITE-START URL重寫規則引用,修改後将導緻面闆設置的僞靜态規則失效
    include /www/host/domain/vhost/rewrite/domain.dobunkan.com.conf;
    #REWRITE-END
    
    #禁止訪問的文件或目錄
    location ~ ^/(\.user.ini|\.htaccess|\.git|\.svn|\.project|LICENSE|README.md)
    {
        return 404;
    }
    
    #一鍵申請SSL證書驗證目錄相關設置
    location ~ \.well-known{
        allow all;
    }
    
    location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$
    {
        expires      30d;
        error_log off;
        access_log off;
    }
    
    location ~ .*\.(js|css)?$
    {
        expires      12h;
        error_log off;
        access_log off; 
    }
    access_log  /www/wwwlogs/domain.dobunkan.com.log;
    error_log  /www/wwwlogs/domain.dobunkan.com.error.log;

}

非常笨的方法順利的解決了nginx301跳轉的問題,如果你有更好的方法,請在下方留言!!!

原文鏈接:https://www.sobuer.com/server/147,轉載請注明出處。
0

評論0

請先
這裏部分資源由本站原創,部分來自互聯網,所有資源僅供學習使用,請勿商用!!!客服QQ:125252828
顯示驗證碼
沒有賬号?注冊  忘記密碼?

社交賬号快速登錄

微信掃一掃關注
如已關注,請回複“登錄”二字獲取驗證碼