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 重寫就配置完畢了。
配置后,根目錄下的web.config文件的內容如下:
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<system.webServer>
<rewrite>
<rules>
<rule name="redirect to HTTPS" enabled="true" stopProcessing="true">
<match url="(.*)" />
<conditions>
<add input="{HTTPS}" pattern="^OFF$" />
</conditions>
<action type="Redirect" url="https://{HTTP_HOST}/{R:1}" />
</rule>
</rules>
</rewrite>
</system.webServer>
</configuration>
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]
來源:月光博客