IIS和Apache實(shí)現(xiàn)HTTP重定向到HTTPS
本文介紹IIS7和Apache上實(shí)現(xiàn)訪問(wèn)HTTP跳轉(zhuǎn)到HTTPS訪問(wèn)的方法,網(wǎng)站設(shè)計(jì)出于安全的考慮需要使用https協(xié)議,但不少用戶因?yàn)檩斎刖W(wǎng)址的習(xí)慣不喜歡帶上https協(xié)議,導(dǎo)致訪問(wèn)異常,因此需要一種重定向功能,實(shí)現(xiàn)HTTP網(wǎng)站重定向到HTTPS網(wǎng)站的方法,具體操作如下。
IIS7
從微軟的官方網(wǎng)站下載HTTP重寫模塊,安裝完畢之后重啟IIS服務(wù),之后打開(kāi)IIS控制臺(tái),發(fā)現(xiàn)多了一個(gè)組件,雙擊“URL重寫”,在右邊窗體中選擇“添加規(guī)則”,并添加一個(gè)空白規(guī)則,給規(guī)則自定義一個(gè)名字(名稱自便),比如我這里叫“redirect to HTTPS”,模式為:(.*),添加一個(gè)條件,條件輸入為 {HTTPS},與模式匹配,模式為 ^OFF$,然后配置操作,操作類型為:重定向,重定向到URL為:https://{HTTP_HOST}/{R:1},重定向類型:永久301。
設(shè)置完畢后點(diǎn)擊右側(cè)的“應(yīng)用”,這個(gè) URL 重寫就配置完畢了。
配置后,根目錄下的web.config文件的內(nèi)容如下:
<?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]
來(lái)源:月光博客