雖然以前的文章沒有了,但我至少得保證原來到域名能夠繼續(xù)訪問到新的博客,瀏覽到新的文章,于是想起用htaccess來做重定向。這次對htaccess的寫法做個記錄,免得今后還要到處搜羅。
這是我這次用到的幾條重定向規(guī)則
復制代碼 代碼如下:
RewriteEngine on
#silentash全局切換
Rewritecond %{HTTP_HOST} ^(www\.)?silentash.com$ [nc]
Rewriterule ^(.*)$ http://jb51.net/$1 [r=301,nc]
#blog對應切換
Rewritecond %{HTTP_HOST} ^blog.silentash.com$ [nc]
Rewriterule ^(.*)$ http://jb51.net/blog [r=301,nc]
#app對應切換
Rewritecond %{HTTP_HOST} ^app.silentash.com$ [nc]
Rewriterule ^(.*)$ http://jb51.net/app/$1 [r=301,nc]
#lab對應切換
Rewritecond %{HTTP_HOST} ^lab.silentash.com$ [nc]
Rewriterule ^(.*)$ http://jb51.net/lab/$1 [r=301,nc]
#photo對應切換
Rewritecond %{HTTP_HOST} ^photo.silentash.com$ [nc]
Rewriterule ^(.*)$ http://jb51.net/photo/$1 [r=301,nc]
#只訪問主域的先切換到博客
Rewritecond %{HTTP_HOST} ^(www.)?jb51.net$ [nc]
Rewritecond %{REQUEST_URI} ^(\/)?$ [nc]
Rewriterule ^(.*)$ http://jb51.net/blog [r=301,nc]
下面簡單解說下上面的意思:
【RewriteEngine On】表示重寫引擎開,關閉off,關閉的話當然就不能做轉發(fā)了。
【Rewritecond %{HTTP_HOST} ^(www\.)?silentash.com$ [nc]】
這是重寫條件,前面%{HTTP_HOST}表示當前訪問的網(wǎng)址,只是指前綴部分,格式是www.silentash.com不包括“http://”和“/”,^表示字符串開始,$表示字符串結尾,\.表示轉義的. ,如果不轉義也行,推薦轉義,防止有些服務器不支持,?表示前面括號www\.出現(xiàn)0次或1次,這句規(guī)則的意思就是如果訪問的網(wǎng)址是silentash.com或者www.silentash.com就執(zhí)行以下的語句,不符合就跳過。
【Rewriterule ^(.*)$ http://jb51.net/$1 [r=301,nc]】
這個根據(jù)之前的條件執(zhí)行相應的規(guī)則,在這里的話就是讓重定向到jb51.net域下面相應地址,比如來源地址是http://www.silentash.com/abc/1.html,前部分的^(.*)$將會匹配當前請求的url,不過這里到底是匹配整個http://www.silentash.com/abc/1.html,還是只匹配/abc/1.html即反斜杠后面的成分,還是只匹配abc/1.html?
答案是:根據(jù)RewriteBase規(guī)則規(guī)定,如果rewritebase 為/,將會匹配abc/1.html,默認應該是abc/1.html。后面的$1是正則匹配出來的值,經(jīng)過組合,之前的url會被重定向為http://jb51.net/abc/1.html,達到了域名轉換的目的。
后面幾行大同小異。
還有一個問題是,不能保證每個人輸入的網(wǎng)址都是小寫的,如果輸入大寫的呢,linux系統(tǒng)是區(qū)分大小寫的,所以應該在RewriteCond后添加[NC]忽略大小寫的。
下面附上簡單的語法規(guī)則和flags:
【RewriteCond語法:】
RewriteCond TestString CondPattern [flags]
rewritecond的其他用法:
‘-d'(目錄)
將TestString視為一個路徑名并測試它是否為一個存在的目錄。
‘-f'(常規(guī)文件)
將TestString視為一個路徑名并測試它是否為一個存在的常規(guī)文件。
‘-s'(非空的常規(guī)文件)
將TestString視為一個路徑名并測試它是否為一個存在的、尺寸大于0的常規(guī)文件。
‘-l'(符號連接)
將TestString視為一個路徑名并測試它是否為一個存在的符號連接。
‘-x'(可執(zhí)行)
將TestString視為一個路徑名并測試它是否為一個存在的、具有可執(zhí)行權限的文件。該權限由操作系統(tǒng)檢測。
‘-F'(對子請求存在的文件)
檢查TestString是否為一個有效的文件,而且可以在服務器當前的訪問控制配置下被訪問。它使用一個內(nèi)部子請求來做檢查,由于會降低服務器的性能,所以請謹慎使用!
‘-U'(對子請求存在的URL)
檢查TestString是否為一個有效的URL,而且可以在服務器當前的訪問控制配置下被訪問。它使用一個內(nèi)部子請求來做檢查,由于會降低服務器的性能,所以請謹慎使用!
【RewriteRule語法:】
RewriteRule Pattern Substitution [flags]
【flags】:
‘chain|C'(鏈接下一規(guī)則)
此標記使當前規(guī)則與下一個規(guī)則相鏈接。它產(chǎn)生這樣的效果:如果一個規(guī)則被匹配,則繼續(xù)處理其后繼規(guī)則,也就是這個標記不起作用;如果該規(guī)則不被匹配,則其后繼規(guī)則將被跳過。比如,在一個目錄級規(guī)則中執(zhí)行一個外部重定向時,你可能需要刪除”.www”(此處不應該出現(xiàn)”.www”)。
‘cookie|CO=NAME:VAL:domain[:lifetime[:path]]'(設置cookie)
在客戶端設置一個cookie。cookie的名稱是NAME,值是VAL。domain是該cookie的域,比如'.apache.org',可選的lifetime是cookie的有效期(分鐘),可選的path是cookie的路徑。
‘env|E=VAR:VAL'(設置環(huán)境變量)
此標記將環(huán)境變量VAR的值為VAL,VAL可以包含可擴展的正則表達式反向引用($N和%N)。此標記可以多次使用以設置多個變量。這些變量可以在其后許多情況下被間接引用,通常是在XSSI(!–#echo var=”VAR”–>)或CGI($ENV{‘VAR'})中,也可以在后繼的RewriteCond指令的CondPattern參數(shù)中通過%{ENV:VAR}引用。使用它可以記住從URL中剝離的信息。
‘forbidden|F'(強制禁止URL)
強制禁止當前URL,也就是立即反饋一個HTTP響應碼403(被禁止的)。使用這個標記,可以鏈接若干個RewriteConds來有條件地阻塞某些URL。
‘gone|G'(強制廢棄URL)
強制當前URL為已廢棄,也就是立即反饋一個HTTP響應碼410(已廢棄的)。使用這個標記,可以標明頁面已經(jīng)被廢棄而不存在了。
‘handler|H=Content-handler'(強制指定內(nèi)容處理器)
強自制定目標文件的內(nèi)容處理器為Content-handler。例如,用來模擬mod_alias模塊的ScriptAlias指令,以強制映射文件夾內(nèi)的所有文件都由”cgi-script”處理器處理。
‘last|L'(結尾規(guī)則)
立即停止重寫操作,并不再應用其他重寫規(guī)則。它對應于Perl中的last命令或C語言中的break命令。這個標記用于阻止當前已被重寫的URL被后繼規(guī)則再次重寫。例如,使用它可以重寫根路徑的URL(‘/')為實際存在的URL(比如:'/e/www/')。
‘next|N'(從頭再來)
重新執(zhí)行重寫操作(從第一個規(guī)則重新開始)。此時再次進行處理的URL已經(jīng)不是原始的URL了,而是經(jīng)最后一個重寫規(guī)則處理過的URL。它對應于Perl中的next命令或C語言中的continue命令。此標記可以重新開始重寫操作(立即回到循環(huán)的開頭)。但是要小心,不要制造死循環(huán)!
‘nocase|NC'(忽略大小寫)
它使Pattern忽略大小寫,也就是在Pattern與當前URL匹配時,'A-Z'和'a-z'沒有區(qū)別。
‘noescape|NE'(在輸出中不對URI進行轉義)
此標記阻止mod_rewrite對重寫結果應用常規(guī)的URI轉義規(guī)則。 一般情況下,特殊字符(‘%', ‘$', ‘;'等)會被轉義為等值的十六進制編碼(‘%25′, ‘%24′, ‘%3B'等)。此標記可以阻止這樣的轉義,以允許百分號等符號出現(xiàn)在輸出中,比如:
RewriteRule /foo/(.*) /bar?arg=P1\%3d$1 [R,NE]
可以使'/foo/zed轉向到一個安全的請求'/bar?arg=P1=zed'。
‘nosubreq|NS'(不對內(nèi)部子請求進行處理)
在當前請求是一個內(nèi)部子請求時,此標記強制重寫引擎跳過該重寫規(guī)則。比如,在mod_include試圖搜索目錄默認文件(index.xxx)時,Apache會在內(nèi)部產(chǎn)生子請求。對于子請求,重寫規(guī)則不一定有用,而且如果整個規(guī)則集都起作用,它甚至可能會引發(fā)錯誤。所以,可以用這個標記來排除某些規(guī)則。
使用原則:如果你為URL添加了CGI腳本前綴,以強制它們由CGI腳本處理,但對子請求處理的出錯率(或者資源開銷)很高,在這種情況下,可以使用這個標記。
‘proxy|P'(強制為代理)
此標記使替換成分被內(nèi)部地強制作為代理請求發(fā)送,并立即中斷重寫處理,然后把處理移交給mod_proxy模塊。你必須確保此替換串是一個能夠被mod_proxy處理的有效URI(比如以http://hostname開頭),否則將得到一個代理模塊返回的錯誤。使用這個標記,可以把某些遠程成分映射到本地服務器域名空間,從而增強了ProxyPass指令的功能。
注意:要使用這個功能,必須已經(jīng)啟用了mod_proxy模塊。
‘passthrough|PT'(移交給下一個處理器)
此標記強制重寫引擎將內(nèi)部request_rec結構中的uri字段設置為filename字段的值,這個小小的修改使得RewriteRule指令的輸出能夠被(從URI轉換到文件名的)Alias, ScriptAlias, Redirect等指令進行后續(xù)處理[原文:This flag is just a hack to enable post-processing of the output of RewriteRule directives, using Alias, ScriptAlias, Redirect, and other directives from various URI-to-filename translators.]。舉一個能說明其含義的例子: 如果要將/abc重寫為/def, 然后再使用mod_alias將/def轉換為/ghi,可以這樣:
RewriteRule ^/abc(.*) /def$1 [PT]
Alias /def /ghi
如果省略了PT標記,雖然將uri=/abc/…重寫為filename=/def/…的部分運作正常,但是后續(xù)的mod_alias在試圖將URI轉換到文件名時會遭遇失效。
注意:如果需要混合使用多個將URI轉換到文件名的模塊時,就必須使用這個標記。。此處混合使用mod_alias和mod_rewrite就是個典型的例子。
‘qsappend|QSA'(追加查詢字符串)
此標記強制重寫引擎在已有的替換字符串中追加一個查詢字符串,而不是簡單的替換。如果需要通過重寫規(guī)則在請求串中增加信息,就可以使用這個標記。
‘redirect|R [=code]‘(強制重定向)
若Substitution以http://thishost[:thisport]/(使新的URL成為一個URI)開頭,可以強制性執(zhí)行一個外部重定向。如果沒有指定code,則產(chǎn)生一個HTTP響應碼302(臨時性移動)。如果需要使用在300-400范圍內(nèi)的其他響應代碼,只需在此指定即可(或使用下列符號名稱之一:temp(默認), permanent, seeother)。使用它可以把規(guī)范化的URL反饋給客戶端,如將”/~”重寫為”/u/”,或始終對/u/user加上斜杠,等等。
注意:在使用這個標記時,必須確保該替換字段是一個有效的URL。否則,它會指向一個無效的位置!并且要記住,此標記本身只是對URL加上http://thishost[:thisport]/前綴,重寫操作仍然會繼續(xù)進行。通常,你還會希望停止重寫操作而立即重定向,那么就還需要使用'L'標記。
‘skip|S=num'(跳過后繼規(guī)則)
此標記強制重寫引擎跳過當前匹配規(guī)則之后的num個規(guī)則。它可以模擬if-then-else結構:最后一個規(guī)則是then從句,而被跳過的skip=N個規(guī)則是else從句。注意:它和'chain|C'標記是不同的!
‘type|T=MIME-type'(強制MIME類型)
強制目標文件的MIME類型為MIME-type,可以用來基于某些特定條件強制設置內(nèi)容類型。比如,下面的指令可以讓.php文件在以.phps擴展名調(diào)用的情況下由mod_php按照PHP源代碼的MIME類型(application/x-httpd-php-source)顯示:
RewriteRule ^(.+\.php)s$ $1 [T=application/x-httpd-php-source]
您可能感興趣的文章:- htaccess 防盜鏈,防止目錄瀏覽等10大技巧
- .htaccess文件寫法之作用范圍
- php靜態(tài)化頁面 htaccess寫法詳解(htaccess怎么寫?)
- Apache中.htaccess文件功能
- htaccess 將所有請求重定向到某個URL地址的規(guī)則
- .htaccess文件保護實例講解
- 利用.htaccess的Rewrite規(guī)則實現(xiàn)Discuz論壇的偽靜態(tài)鏈接
- .htaccess使用方法總結
- 最完的htaccess文件用法收集整理