nginx配置http跳轉https


一、需求簡介

基於nginx搭建了一個https訪問的虛擬主機,監聽的域名是test.com,但是很多用戶不清楚https和http的區別,會很容易敲成http://test.com,這時會報出404錯誤,所以我需要做基於test.com域名的http向https的強制跳轉

我總結了三種方式,跟大家共享一下

二、nginx的rewrite方法

 思路

這應該是大家最容易想到的方法,將所有的http請求通過rewrite重寫到https上即可

 配置

server {  
    listen  192.168.1.111:80;  
    server_name test.com;  
      
    rewrite ^(.*)$  https://$host$1 permanent;  
}  

搭建此虛擬主機完成后,就可以將http://test.com的請求全部重寫到https://test.com上了

總體的server模塊配置:

server {
    listen 80;
    server_name shfxx.test.com;
    rewrite ^(.*)$  https://$host$1 permanent;

}


server {
    listen 443 ssl;
    ssl on;
    ssl_certificate /usr/local/nginx/conf/ssl/START-smartcampus-org-cn.pem;
    ssl_certificate_key /usr/local/nginx/conf/ssl/START-smartcampus-org-cn.key;
    ssl_session_timeout 5m;
    ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
    ssl_prefer_server_ciphers on;
    ssl_ciphers ECDHE-RSA-AES256-GCM-SHA384:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-RSA-AES256-SHA384:ECDHE-RSA-AES128-SHA256:ECDHE-RSA-RC4-SHA:ECDHE-RSA-AES256-SHA:DHE-RSA-AES256-SHA:DHE-RSA-AES128-SHA:RC4-SHA:!aNULL
:!eNULL:!EXPORT:!DES:!3DES:!MD5:!DSS:!PKS;
ssl_session_cache builtin:1000 shared:SSL:10m; server_name shfxx.test.com; access_log /data/wwwroot/sfzxxx/logs/access_campus.log combined; error_log /data/wwwroot/sfzxxx/logs/error_campus.log; root /data/wwwroot/sfzxxx/campus; index index.html index.htm index.php; location / { if (!-e $request_filename) { rewrite ^/admin/(.*)$ /admin.php/$1 last; rewrite ^/(.*)$ /index.php/$1 last; } } location ~ [^/]\.php(/|$) { #fastcgi_pass 127.0.0.1:9000; fastcgi_pass unix:/dev/shm/php-cgi.sock; fastcgi_index index.php; fastcgi_split_path_info ^(.+\.php)(.*)$; fastcgi_param PATH_INFO $fastcgi_path_info; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; include fastcgi.conf; } }

三、nginx的497狀態碼

error code 497

497 - normal request was sent to HTTPS  

解釋:當此虛擬站點只允許https訪問時,當用http訪問時nginx會報出497錯誤碼

思路

利用error_page命令將497狀態碼的鏈接重定向到https://test.com這個域名上

配置

server {  
    listen       192.168.1.11:443;  #ssl端口  
    listen       192.168.1.11:80;   #用戶習慣用http訪問,加上80,后面通過497狀態碼讓它自動跳到443端口  
    server_name  test.com;  
    #為一個server{......}開啟ssl支持  
    ssl                  on;  
    #指定PEM格式的證書文件   
    ssl_certificate      /etc/nginx/test.pem;   
    #指定PEM格式的私鑰文件  
    ssl_certificate_key  /etc/nginx/test.key;  
      
    #讓http請求重定向到https請求   
    error_page 497  https://$host$uri?$args;  
}  

四、index.html刷新網頁

 思路

上述兩種方法均會耗費服務器的資源,我們用curl訪問baidu.com試一下,看百度的公司是如何實現baidu.com向www.baidu.com的跳轉
 
可以看到百度很巧妙的利用meta的刷新作用,將baidu.com跳轉到www.baidu.com.因此我們可以基於http://test.com的虛擬主機路徑下也寫一個index.html,內容就是http向https的跳轉

index.html

[html] view plaincopyprint?

<html>  
<meta http-equiv="refresh" content="0;url=https://test.com/">  
</html>  

nginx虛擬主機配置

server {  
    listen 192.168.1.11:80;  
    server_name test.com;  
      
    location / {  
                #index.html放在虛擬主機監聽的根目錄下  
        root /srv/www/http.test.com/;  
    }  
        #將404的頁面重定向到https的首頁  
    error_page  404 https://test.com/;  
}  

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM