.htaccess的功能非常的強大,你可以通過它轉向域名、自定義主頁、自定義404錯誤頁等很多實用功能。對於一些功能不是很全面的控制面板,掌握一些.htaccess的操作,可以讓我們如魚得水,個人體會^_^ o4 r: r, W; `# p6 R% \
9 m! N! E& e5 z/ d
下面是引用的文章,當然我個人覺得記憶比較麻煩,如果你正在建站,推薦你大致看下具體功能,需要的時候可以再看或者是找些在線的網站生成如:http://developers.evrsoft.com/tools-htaccess-generator.shtml即可。& Z: Y) O- w. z9 |5 p
9 ~+ G, _; D j3 W/ ~ b
Apache服務器的.htaccess是一個非常強大的分佈式配置文件,學會使用.htaccess,對虛擬主機用戶來說,可以實現眾多的功能。這裡有一篇很容易理解的.htaccess介紹,作為入門文章非常的適合。文章最初來自freewebmasterhelp.com,QiRan作了簡單的中文翻譯,我將加以完善。9 g' q8 n! x# d; N# `- e9 t8 i
% R5 G4 Z* j& w& S4 Q# CPart 1 – 介紹! c3 Z# k" ]( f3 y: B* y3 Y$ e
Part 2 - .htaccess命令
- a& G. x0 z+ q9 N' `( APart 3 - 密碼保護% p$ C; M- g& [& T% @4 R
/ t3 K8 X% f: tPart 1 - 介紹
; ?# x. n3 j8 H3 k+ T7 w% [$ L
5 c. Q7 U% I L# a* N( m* `9 y介紹2 i3 j# k) K5 G1 C; L2 E
從本指南中,你將可以學習到有關.htaccess文件及其功能的知識,並用以優化你的網站。儘管.htaccess只是一個文件,但它可以更改服務器的設置,允許你做許多不同的事情,最流行的功能是您可以創建自定義的「404 error」頁面。.htaccess並不難於使用,歸根結底,它只是在一個text文檔中添加幾條簡單的指令而已。" Z N! n4 D# h& u5 D- p" p0 A
我的主機支持它嗎?
* W; C% S5 a a& n/ q/ A9 q Z; j# d2 R6 X) h- T1 [+ q+ a# P
這可能很難用簡單的答案來回答。許多主機支持.htaccess,但實際上並不會特別聲明,許多其他類型的主機有能力但並不允許他們的用戶使用.htaccess。一般來說,如果你的主機使用Unix或Linux系統,或任何版本的Apache網絡服務器,從理論上都是支持.htaccess的,儘管你的主機服務商可能不允許你使用它。
7 D6 T* f, {1 X @# S4 t/ o- S) ^ x" T* a
判斷你的主機是否允許.htaccess,一個標誌很好的是它是否支持文件夾密碼保護。為達到此功能,主機服務商需要使用.htaccess(當然,少數情況下他們雖提供密碼保護功能,但卻並不允許你使用.htaccess)。如果你不確定自己的主機是否支持.htaccess,最好的辦法是上傳你自己的.htaccess文件看看是否有用,或者直接發送郵件向你的主機服務商咨詢。" _. |- o; z) G8 S
' E8 }4 _' t+ a% P
我該怎麼做?' x( ~8 J; h: \1 I- C4 Y
你可能疑惑.htaccess到底能做些什麼,或者你可能曾知道它的一些功能但並不真正瞭解你實際到底可以用它來做多少事情。
8 o' u- _8 H+ o# P# H1 z
" d* W( L' M' y/ _+ x0 ].htaccess可以做大量的事情,包括:文件夾密碼保護、用戶自動重定向、自定義錯誤頁面、改變你的文件擴展名、封禁特定IP地址的用戶、只允許特定IP地址的用戶、禁止目錄列表,以及使用其他文件作為index文件。 E; O/ {# P8 Q0 ~! D+ V$ T2 H
# a8 L5 j* D) H: |# D' U4 h" S8 ^
創建一個.htaccess文檔
* c% x A/ \% {* ?$ y7 T創建.htaccess文件也許會給你帶來一些困難。寫文件很容易,你只需要在文字編緝器(例如:寫字板)裡寫下適當的代碼。真正困難的可能是文件的保存,因為.htaccess是一個古怪的文件名(它事實上沒有文件名,只有一個由8個字母組成的擴展名),而在一些系統(如Windows 3.1)中無法接受這樣的文件名。在大多數的操作系統中,你需要做的是將文檔保存成名為:「.htaccess」(包括引號)。如果這也不行,你需要將其先命名為其它名字(例如htaccess.txt),再將其上傳到服務器上,之後直接使用FTP軟件來重命名。
: D5 r# @+ _4 S& d% m
* C' E: v- J0 `警告
3 I, u2 U, U/ r( L) o在使用.htaccess之前,我必須給你一些警告。雖然在服務器上使用.htaccess絕對不太可能給你帶來任何麻煩(如果有些東西錯了,它只是沒效用罷了),但如果你使用Microsoft FrontPage Extensions,就必須特別小心。因為FrontPage Extensions本身使用了.htaccess,因此你不能編輯它並加入你自己的信息。如果確實有這方面的需要(並不推薦,但是可能),你應該先從服務器上下載.htaccess文檔(如果存在),之後在前面加上你的代碼。5 ?! ^ z5 y0 J/ w; Z. x
9 s+ @. t9 I' D/ U B/ F) c! e自定義錯誤頁
7 c1 Q2 h: i8 f) Q* ]. a6 t+ U我要介紹的.htaccess的第一個應用是自定義錯誤頁面,這將使你可以擁有自己的、個性化的錯誤頁面(例如找不到文件時),而不是你的服務商提供的錯 誤頁或沒有任何頁面。這會讓你的網站在出錯的時候看上去更專業。你還可以利用腳本程序在發生錯誤的時候通知你(例如我使用Free Webmaster Help的PHP腳本程序,當找不到頁面的時候自動Email給我)。
% V: U5 Z3 C# x: Z1 M1 L! { W你所知道的任何頁面錯誤代碼(像404找不到頁面),都可以通過在.htaccess文件裡加入下面的文字將其變成自定義頁面:0 f( L4 V1 Q5 Q/ N; L- M
ErrorDocument errornumber /file.html b0 ?6 z0 [4 v7 |+ p% i
舉例來說,如果我的根目錄下有一個notfound.html文件,我想使用它作為404 error的頁面:0 g- X' @5 y% n, _6 z0 T" N2 M
ErrorDocument 404 /notfound.html
/ I- A8 h: J1 N% N如果文件不在網站的根目錄下,你只需要把路徑設置為:, U5 a# |# M# [- \
ErrorDocument 500 /errorpages/500.html% j. t) L; ^; Y$ ?/ A2 n
以下是一些最常用的錯誤:9 A! E6 m* f# g' M& B
401 - Authorization Required 需要驗證
# K0 d( j9 G! C2 k( z+ A4 K400 - Bad request 錯誤請求5 O2 ?0 z: b1 |4 _2 t8 t; u6 I
403 - Forbidden 禁止: I+ J( X! C/ k* g
500 - Internal Server Error 內部服務器錯誤 g) f) m0 r/ {8 ~
404 - Wrong page 找不到頁面' f$ t" B0 ~ P: Y1 g
接下來,你要做的只是創建一個錯誤發生時顯示的文件,然後把它們和.htaccess一起上傳。2 z5 ^- z# E9 x) g, i8 e
2 Z7 ?& t/ r5 x2 ]' a8 E9 {
Part 2 - .htaccess命令
6 Q$ s+ H: k* I8 d' v- G" L. B介紹
0 ?0 u( Q- i! C; o4 R" k) U1 k在上一部分,我已經簡單介紹了.htaccess以及它的一些有用功能,在這一部分,我將向你演示如何使用.htaccess文檔去實現這些功能。
3 U7 k1 }. D& `. E7 g4 _ D停示顯示目錄列表
. f$ _2 D7 o! z. ~. k/ S/ M有些時候,由於某種原因,你的目錄裡沒有index文件,這意味著當有人在瀏覽器地址欄鍵入了該目錄的路徑,該目錄下所有的文件都會顯示出來,這會給你的網站留下安全隱患。9 V) e1 Z/ ~0 u0 h
為避免這種情況(而不必創建一堆的新index文件),你可以在你的.htaccess文檔中鍵入以下命令,用以阻止/ `1 E3 w O2 r8 F8 y, B
% t. {( ~+ l/ t" H! b: M# `
目錄列表的顯示:
! G! }& l) b: }& _Options -Indexes/ M" r3 U4 c" f7 y: j; g
+ j3 n; U! n0 W: T9 A阻止/允許特定的IP地址% k" P7 r! P5 K5 f. H1 O
某些情況下,你可能只想允許某些特定IP的用戶可以訪問你的網站(例如:只允許使用特定ISP的用戶進入某個目錄),或者想封禁某些特定的IP地址(例如:將低級用戶隔離於你的信息版面外)。當然,這只在你知道你想攔截的IP地址時才有用,然而現在網上的大多數用戶都使用動態IP地址,所以這並不是限制使用的常用方法。. n$ g, R E# A" P
你可以使用以下命令封禁一個IP地址:
( J7 y0 Y& r! s7 D/ R* Tdeny from 000.000.000.0004 f0 K# o, A) V+ i; K/ z* C
這裡的000.000.000.000是被封禁的IP地址,如果你只指明了其中的幾個,則可以封禁整個網段的地址。如你輸入210.10.56.,則將封禁210.10.56.0~210.10.56.255的所有IP地址。
7 ~3 Y% v3 s4 p/ A+ W3 p你可以使用以下命令允許一個IP地址訪問網站:: v* B5 i5 T3 H G) [0 d
allow from 000.000.000.0000 N+ Z# d2 n: D3 L' B- h6 o
被允許的IP地址則為000.000.000.000,你可以像封禁IP地址一樣允許整個網段。! V& ?( s- L' i+ x: y X" |
如果你想阻止所有人訪問該目錄,則可以使用:
1 P9 N7 E- [2 x% }deny from all
/ B& _! p$ f$ u' A$ C# x& J i不過這並不影響腳本程序使用這個目錄下的文檔。, k) e2 f9 \) U( c6 p6 h
6 X. u/ ^9 m! f: B替換index文件
# w/ h& b" M D* T3 g0 t也許你不想一直使用index.htm或index.html作為目錄的索引文件。舉例來說,如果你的站點使用PHP文件,你可能會想使用 index.php來作為該目錄的索引文檔。當然也不必局限於「index」文檔,如果你願意,使用.htaccess你甚至能夠設置foofoo.balh來作為你的索引文檔!: d0 d# E: V3 V
這些互為替換的索引文件可以排成一個列表,服務器會從左至右進行尋找,檢查哪個文檔在真實的目錄中存在。如果一個也找不到,它將會把目錄列表顯示出來(除非你已經關閉了顯示目錄文件列表)。
) X' E9 c+ z& @& M1 pDirectoryIndex index.php index.php3 messagebrd.pl index.html index.htm
& S. y7 S% J4 n& S重定向
8 f8 Y B9 ?8 A) ^.htaccess最有用的功能之一就是將請求重定向到同站內或站外的不同文檔。這在你改變了一個文件名稱,但仍然想讓用戶用舊地址訪問到它時,變的極為有用。另一個應用(我發現的很有用的)是重定向到一個長URL,例如在我的時事通訊中,我可以使用一個很簡短的URL來指向我的會員鏈接。以下是一個重定向文件的例子:
; I4 |- d- _% NRedirect /location/from/root/file.ext http://www.othersite.com/new/file/location.xyz
- h* i1 S- A* h/ f上述例子中,訪問在root目錄下的名為oldfile.html可以鍵入:0 o* O2 r+ F- u% h; r
/oldfile.html2 R5 \7 K; H( i5 ]5 Z& T. X/ j
訪問一個舊次級目錄中的文件可以鍵入:) y& F1 i) e& u
/old/oldfile.html
8 q& z+ E' {2 K; c6 d你也可以使用.htaccess重定向整個網站的目錄。假如你的網站上有一個名為olddirectory的目錄,並且你已經在一個新網站http://www.newsite.com/newdirectory/上建立了與上相同的文檔,你可以將舊目錄下所有的文件做一次重定向而不必一一聲明:" A! E! \: O* L% y k6 E, J
Redirect /olddirectory http://www.newsite.com/newdirectory/ ^" S2 _0 _& c. m/ \
這樣,任何指向到站點中/olddirectory目錄的請求都將被重新指向新的站點,包括附加的額外URL信息。例如有人鍵入:
" C" V4 U* C+ \) x7 phttp://www.youroldsite.com/olddirecotry/oldfiles/images/image. gif, ?+ I$ b! P3 i3 n" W8 V9 C+ A
請求將被重定向到:+ d" m8 O9 P y
http://www.newsite.com/newdirectory/oldfiles/images/image. gif) S3 q7 x8 Z0 F `3 x9 U+ o* V0 T$ H
如果正確使用,此功能將極其強大。
3 G( b# ^! V7 O# l* R# J# b% p/ D! R
Part 3 – 密碼保護5 u& \. x* x+ _' ]
Introduction 介紹2 P! v! m8 `* ?
儘管有各種各樣的.htaccess用法,但至今最流行的也可能是最有用的做法是將其用於網站目錄可靠的密碼保護。儘管JavaScript等也能做到,但只有.htaccess具有完美的安全性(即訪問者必須知曉密碼才可以訪問目錄,並且絕無「後門」可走)。
2 f' M8 o! {+ M' _, a8 _/ P; U/ X密碼保護的.htaccess文件- s% r1 y$ n, Q# [- o
利用.htaccess將一個目錄加上密碼保護分兩個步驟。第一步是在你的.htaccess文檔裡加上適當的幾行代碼,再將.htaccess文檔放進你要保護的目錄下:
" e) n6 R, O2 Q% t5 \; T' ?AuthName 「Section Name」
% W. I3 z; {8 o& t# D2 OAuthType Basic
' ^ C7 I4 K2 |/ s5 WAuthUserFile /full/path/to/.htpasswd7 U1 M9 b* L) f9 M* y$ r7 R3 V; X
Require valid-user* g1 A/ _3 Z4 K: J7 O! I2 V
你可能需要根據你的網站情況修改一下上述內容中的一些部分,如用被保護部分的名字」Members Area」,替換掉「Section Name」。: M+ ^; x O: D9 V
/full/parth/to/.htpasswd則應該替換為指向.htpasswd文件(後面詳述該文檔)的完整服務器路徑。如果你不知道你網站空間的完整路徑,請詢問一下你的系統管理員。+ S- k) V; q' B& v
密碼保護的.htpasswd文件0 ?" j4 @( w& \: u
目錄的密碼保護比.htaccess的其他功能要麻煩些,因為你必須同時創建一個包含用戶名和密碼的文檔,用於訪問你的網站,相關信息(默認)位於一個名為.htpasswd的文檔裡。像.htaccess一樣,.htpasswd也是一個沒有文件名且具有8位擴展名的文檔,可以放置在你網站裡的任何地方(此時密碼應加密),但建議你將其保存在網站Web根目錄外,這樣通過網絡就無法訪問到它了。# C* w5 @0 P* T
輸入用戶名和密碼& V8 Y5 g6 P3 q9 M! w
創建好.htpasswd文檔後(可以通過文字編輯器創建),下一步是輸入用於訪問網站的用戶名和密碼,應為:2 @1 z+ M* S# B' O; `6 B( \
username:password" y; ?: `) |" w/ ?. |
「password」的位置應該是加密過的密碼。你可以通過幾種方法來得到加密過的密碼:一是使用一個網上提供的permade腳本或自己寫一個;另一個很不錯的username/password加密服務是通過KxS網站,這裡允許你輸入用戶名及密碼,然後生成正確格式的密碼。
5 M; y$ w3 v7 R3 v& q對於多用戶,你只需要在.htpasswd文檔中新增同樣格式的一行即可。另外還有一些免費的腳本程序可以方便地管理.htpasswd文檔,可以自動新增/移除用戶等。% C6 d2 D* J3 |3 U) ^0 ?$ D
訪問網站! Z( e: a& M6 B, b$ E9 l" o
當你試圖訪問被.htaccess密碼保護的目錄時,你的瀏覽器會彈出標準的username/password對話窗口。如果你不喜歡這種方式,有些腳本程序可以允許你在頁面內嵌入username/password輸入框來進行認證,你也可以在瀏覽器的URL框內以以下方式輸入用戶名和密碼(未加密 的):. f6 S5 l: Z* ~- p8 Y
http://username:[email protected]/directory/
. O4 h/ T3 K7 V' A' X7 o% a) ?9 n6 o
小結8 S- z6 j. ?7 U. q
.htaccess是一個站點管理員可以應用的強大工具,有更多的變化以適應不同的用途,可以節約時間及提高網站的安全性。( g$ e& B" H5 v) _& n
相關閱讀:
) u' q. |) r* vKxS Password Encrypter5 ?) Y. Y" U$ T5 ]+ Q
Apache .htaccess Documentation5 P! O* B* C& d9 }7 t
More .htaccess Sites2 W/ i" g9 r r \1 M1 J" V1 I5 C
Related Reading1 g4 X; j- J* g" @5 Z2 I, }
.htaccess的特別說明
3 o* T7 r! [1 W8 @# ]啟用.htaccess,需要修改httpd.conf,啟用AllowOverride,並可以用AllowOverride限制特定命令的使用5 X' J v* S0 q; B f8 d. d
如果需要使用.htaccess以外的其他文件名,可以用AccessFileName指令來改變。例如,需要使用.config ,則可以在服務器配置文件中按以下方法配置:9 {& o( ]- D. j" ?( @8 L4 A* e
AccessFileName .config
9 h6 N) q; ]- e" o) a5 g一般情況下,不應該使用.htaccess文件,除非你對主配置文件沒有訪問權限。有一種很常見的誤解,認為用戶認證只能通過.htaccess文件實現,其實並不是這樣,把用戶 認證寫在主配置文件中是完全可行的,而且是一種很好的方法。.htaccess文件應該被用在內容提供者需要針對特定目錄改變服務器的配置而又沒有root權限的情況下。如果服務器管理員不願意頻繁修改配置,則可以允許用戶通過.htaccess文件自己修改配置,尤其是ISP在同一個機器上運行了多個用戶站點,而又希望用戶可以自己改變配置的情況下。雖然如此,一般都應該盡可能地避免使用.htaccess文件。任何希望放在.htaccess文件中的配置,都可以放在主配置文件的段中,而且更高效。避免使用.htaccess文件有兩個主要原因,即性能和安全。 |
評分
-
查看全部評分
|