IIS和Apache實現HTTP重定向到HTTPS
本文介紹IIS7和Apache上實現訪問HTTP跳轉到HTTPS訪問的方法,網站設計出于安全的考慮需要使用https協議,但不少用戶因為輸入網址的習慣不喜歡帶上https協議,導致訪問異常,因此需要一種重定向功能,實現HTTP網站重定向到HTTPS網站的方法,具體操作如下。
IIS7
從微軟的官方網站下載HTTP重寫模塊,安裝完畢之后重啟IIS服務,之后打開IIS控制臺,發現多了一個組件,雙擊“URL重寫”,在右邊窗體中選擇“添加規則”,并添加一個空白規則,給規則自定義一個名字(名稱自便),比如我這里叫“redirect to HTTPS”,模式為:(.*),添加一個條件,條件輸入為 {HTTPS},與模式匹配,模式為 ^OFF$,然后配置操作,操作類型為:重定向,重定向到URL為:https://{HTTP_HOST}/{R:1},重定向類型:永久301。
設置完畢后點擊右側的“應用”,這個 URL 重寫就配置完畢了。
Apache
修改.htaccess文件,在文件里增加如下幾行:
RewriteEngine On
RewriteBase /
RewriteCond %{HTTPS} !=on
RewriteRule ^ https://%{HTTP_HOST}%{REQUEST_URI} [L,R=301]
另一種寫法是:
RewriteEngine on
RewriteBase /
RewriteCond %{SERVER_PORT} !^443$
RewriteRule (.*) https://%{SERVER_NAME}/$1 [R=301,L]