.htaccess文件用好的話對網站安全及網站綜合設置能起到很好的輔助作用。很多新手(包括我)對此文件的設置有很多不明白,本人在網上搜索了一些比較好的應用實例,希望對大家有所幫助!
+ S9 Z: ^/ X3 M: L# ] q6 p9 d2 ?, ]' z4 e# S/ b+ Z. {* z
一、如何創建.htaccess文件
1 T5 x9 s: d( R7 w* A方法1.9 p) ~; q1 O# n x. I% b
- <font size="3">1. 新建 Windows記事本,並打開;
$ }9 Z {: A2 Q. J6 r, r! f - 2. 選取另存新文件「文件->另存為」;. ]: i* a: U+ h( K% L
- 3. 在另存為的「保存類型」下拉選單中選取「所有文件」類型;0 d& J/ Y3 X9 S/ Y
- 4. 這時就可在」文件名」中輸入 .htaccess ;- a# g4 l4 j. J3 P. N% t/ f
- 5. 選取要另存的路徑再按下保存,一個.htaccess 文件就新增完成。</font>
複製代碼 方法2.此時的cmd窗口路徑是C:\Documents and Settings\username>
' v: I0 Q; M" l; w鍵入以下(不包括括號內信息):- copy con .htaccess (回車)
( f# ^0 g1 k4 r0 f - (按Ctrl+Z 回車)
複製代碼 屏幕提示如下:- C:\Documents and Settings\admin>copy con .htaccess
& K$ f% u3 h7 t- A, n' t+ a8 j - ^Z" u$ b" d$ C" _9 S6 R
- 已複製 1 個文件。
複製代碼 此時回到桌面,雙擊我的電腦進入C:\Documents and Settings\username' w. ~/ R4 K: @% N2 A: o
即可看到你想要的文件 ".htaccess"" Q6 L6 y$ P; i$ Q4 e
* e5 Q1 G/ C% H% y1 P2 K
二、.htaccess文件設置技巧23個規則
4 O, z) d/ _/ X* E5 B只適用於linux主機,WIN主機無法定義
7 J' ^# P: t% Y4 s$ S- e" \8 H.htaccess 文件 (Hypertext Access file) 是Apache Web服務器的一個非常強大的配置文件,對於這個文件,Apache有一堆參數可以讓你配置出幾乎隨心所欲的功能。+ `0 v+ s! w6 L! p8 S; B: i
另外,因為.htaccess 是一個相當強大的配置文件,所以,一個輕微的語法錯誤會造成你整個網站的故障,所以,在你修改或是替換原有的文件時,一定要備份舊的文件,以便出現問題的時候可以方便的恢復。) y6 }2 Q7 {/ J
1. 使用.htaccess 創建自定義的出錯頁面。對於Linux Apache來說這是一項極其簡單的事情。使用下面的.htaccess語法你可以輕鬆的完成這一功能。(把.htaccess放在你的網站根目錄下)- ErrorDocument 401 /error/401.php8 ^" l7 j4 ~/ n: I% L
- ErrorDocument 403 /error/403.php! \2 O8 {% [% z3 ?! [. w
- ErrorDocument 404 /error/404.php
w k4 k9 G6 L - ErrorDocument 500 /error/500.php
複製代碼 2. 設置網站的時區- SetEnv TZ America/Houston
複製代碼 3. 阻止IP列表( ^: I: ]/ S' z1 @, R
有些時候,你需要以IP地址的方式阻止一些訪問。無論是對於一個IP地址還是一個網段,這都是一件非常簡單的事情,如下所示:- allow from all( v# }- _) c( |4 z4 E
- deny from 145.186.14.122
" s5 \' x, r8 T4 {4 w - deny from 124.15
複製代碼 Apache對於被拒絕的IP會返回403錯誤。
( _7 m9 h* U. c1 I |1 w/ K" q0 a4. 把一些老的鏈接轉到新的鏈接上——搜索引擎優化SEO- Redirect 301 /d/file.htmlhttp://www.htaccesselite.com/r/file.html
複製代碼 5. 為服務器管理員設置電子郵件。6. 使用.htaccess 防止盜鏈。如果你網站上的一個圖片被別的N多的網站引用了,那麼,這很有可能會導致你服務器的性能下降,使用下面的代碼可以保護某些熱門的鏈接不被過多的引用。- Options +FollowSymlinks# C; O! F) b: R1 O f
- # Protect Hotlinking6 }$ }3 U% O* ~+ b/ w! {
- RewriteEngine On
$ `3 {' g; G& n; D* x' B - RewriteCond %{HTTP_REFERER} !^$
' C) s4 O1 z8 k - RewriteCond %{HTTP_REFERER} !^http://(www.)?domainname.com/[nc], O2 x2 T! B X" m. @) m9 F
- RewriteRule .*.(gif|jpg|png)$http://www.th7.cn/Article/UploadFiles/200908/20090824122550889.png[nc]
複製代碼 7. 阻止 User Agent 的所有請求- ## .htaccess Code :: BEGIN
3 ^2 ]" `* i* x- \: T" }, S - ## Block Bad Bots by user-Agent* S% O2 t- Z9 B- M. ?% y% |
- SetEnvIfNoCase user-Agent ^FrontPage [NC,OR]) }& g( o' S+ `4 ~4 S
- SetEnvIfNoCase user-Agent ^Java.* [NC,OR]
2 y# k/ D% b" R' a% W6 E) U0 @0 X+ o - SetEnvIfNoCase user-Agent ^Microsoft.URL [NC,OR]
8 u. Y% _, H& L - SetEnvIfNoCase user-Agent ^MSFrontPage [NC,OR]1 O: {6 W+ s- ]$ H, y) \0 @% p
- SetEnvIfNoCase user-Agent ^Offline.Explorer [NC,OR]7 s3 f2 i# Q/ m. T0 V
- SetEnvIfNoCase user-Agent ^[Ww]eb[Bb]andit [NC,OR]$ H; _7 x/ ~7 |
- SetEnvIfNoCase user-Agent ^Zeus [NC]5 n+ F0 g4 k" I. j1 G, }! A' U% e
- Order Allow,Deny
( [7 Q( c+ k" X - Allow from all
8 f& M" K/ R# {7 J: F5 _# Q - Deny from env=bad_bot
2 H# E* U9 n4 x5 E3 R6 ^6 I. s - ## .htaccess Code :: END
複製代碼 8. 把某些特殊的IP地址的請求重定向到別的站點- ErrorDocument 403http://www.youdomain.com5 a5 Q# o+ e+ T0 p: v1 q' [+ W1 \
- Order deny,allow
: n! f+ y: G7 O0 I - Deny from all; K& w/ @3 v+ R
- Allow from 124.34.48.165
3 k% D1 j" e0 e- k - Allow from 102.54.68.123
複製代碼 9. 直接找開文件而不是下載– 通常,我們打開網上文件的時候總是會出現一個對話框問我們是下載還是直接打開,使用下面的設置就不會出現這個問題了,直接打開。- AddType application/octet-stream .pdf
! W3 d0 h5 }* Q! Z - AddType application/octet-stream .zip
m1 ~: f- |: H. R4 y - AddType application/octet-stream .mov
複製代碼 10. 修改文件類型– 下面的示例可以讓任何的文件都成為PHP那麼被服務器解釋。比如:myphp, cgi,phtml等。- ForceType application/x-httpd-php
& K" c+ J2 [1 ~4 v( x* L - SetHandler application/x-httpd-php
複製代碼 11. 阻止存取.htaccess 文件- # secure htaccess file) v2 a n \' l$ [' }+ F
- order allow,deny, p8 ~( v' d Q2 w5 j; h
- deny from all
複製代碼 12. 保護服務器上的文件被存取- # prevent access of a certain fileorder allow,deny
8 A$ U' ?0 w( T. i( i% Q. R - deny from all
複製代碼 13. 阻止目錄瀏覽- # disable directory brow9 m/ S9 k5 f0 T. H6 y$ C4 `
- sing
+ k6 c u5 [0 q: q; V - Options All -Indexes
複製代碼 14. 設置默認主頁- # serve alternate default index page
5 s1 ?7 D0 `, D2 @' S6 W. J) C3 j2 J - DirectoryIndex about.html
複製代碼 15. 口令認證– 你可以創建一個文件用於認證。下面是一個示例:- # to protect a file
9 t/ O/ O4 O. @2 | v - AuthType Basic
: U( ]7 ?8 Q! y' _* c - AuthName 「Prompt」
, e7 y) M5 Q3 C - AuthUserFile /home/path/.htpasswd/ |) J0 [7 o6 q+ g0 o- R
- Require valid-user
& [" p9 f1 b. H& T - # password-protect a directory4 q3 }* X& L& h1 f# _8 `
- resides9 c$ }0 z, l; X4 k1 {2 b& \$ D
- AuthType basic
( e0 u+ X% ]6 k1 B, l - AuthName 「This directory is protected」
f* K$ x8 J& z- S$ x$ w1 t4 k6 f - AuthUserFile /home/path/.htpasswd% q% T( Q3 x* c# |7 H
- AuthGroupFile /dev/null# t6 M0 x* s- f2 {& f
- Require valid-user
複製代碼 16. 把老的域名轉像新的域名- # redirect from old domain to new domain1 t& @% N- ^2 K2 o F$ y
- RewriteEngine On7 }% z' f0 ~) ^% S2 u6 R) {& s
- RewriteRule ^(.*)$http://www.yourdomain.com/$1[R=301,L]
複製代碼17.防盜鏈 圖片的盜鏈可能是很多站長最為頭痛的事情,自己的圖片被人白白拿去不說,還會免費佔用了自己網站的資源,使用htaccess文件同樣可以實現防盜鏈的功能。代碼如下: - RewriteEngine On
# s% G1 i' u% k - RewriteCond %{HTTP_REFERER} !^http://domain.com/.*$ [NC]
! W" L0 y, _+ i9 E, \0 b - RewriteCond %{HTTP_REFERER} !^http://domain.com$ [NC]
: V* w0 g. }( W2 v' T+ l - RewriteCond %{HTTP_REFERER} !^http://www.domain.com/.*$ [NC]
- {0 [( H$ J% W% \. X - RewriteCond %{HTTP_REFERER} !^http://www.domain.com$ [NC]0 l$ t5 d) v2 o
- RewriteRule .*\.(gif|jpg|jpeg|png|bmp|swf|mp3|wav|zip|rar)$ http://www.domain.com/404.html [R,NC]
複製代碼這段代碼會判斷請求的referer,如果鏈接不是從本站點擊過來的,默認都會跳轉到一個404頁面。在RewriteRule中指定了要防盜鏈的文件類型。 18.防止垃圾評論 例用htaccess同樣可以防止一部分來源不明的垃圾評論: - RewriteEngine On
& D1 y8 U2 [) R- Z) M) i2 H5 E - RewriteCond %{REQUEST_METHOD} POST- n0 ~$ x, \" g( @
- RewriteCond %{REQUEST_URI} .wp-comments-post\.php*
4 X) E" `, R( Q* v - RewriteCond %{HTTP_REFERER} !.*domain.com.* [OR]
" {9 }+ M: {2 |1 B - RewriteCond %{HTTP_USER_AGENT} ^$
6 v* k+ K o2 l8 d/ L% H# j/ I - RewriteRule (.*) ^http://domain.com/$ [R=301,L]
複製代碼這段代碼,判斷一個POST請求是否是由瀏覽器發出的(判斷HTTP_USER_AGENT是否為空),並且Refer是否本站的,只要其中任意一個條件不滿足,就將請求自動跳轉到首頁。 注意,這段代碼只適用於Wordpress,其實的框架可以根據其具體情況把wp-comments-post修改成對應的URL。 19.只允許自己訪問Wordpress的後台 如果你有一個固定的IP,那麼你完全可以在htaccess中設定只有自己能訪問Wordpress的後台。在wp-admin目錄下建立一個新的.htaccess文件,裡面寫入如下代碼: - AuthUserFile /dev/null2 v! j f; m5 ^: M' x7 e5 f
- AuthGroupFile /dev/null
( |/ M; r3 y' f3 N1 J* R - AuthType Basic* O" ?( q; E" M+ ]
- <LIMIT GET>& I# R6 P# \4 |; u' p3 p7 a
- order deny,allow
9 J) V- B7 Q, O1 N) M. i% b0 T) l - deny from all- u- n" N* K7 \
- ) X8 Z/ F; d: |' K, v- `
- # xx.xx.xx.xx為您的IP,您也以設定多個IP。- D% D/ _) u( D" Z5 d
- allow from xx.xx.xx.xx
+ U7 @% `6 B. ?2 \- ]: [# w - allow from xx.xx.xx.xxx+ \9 ^, b3 G3 v6 a
- </LIMIT>
複製代碼註:對於這段代碼,一定是在wp-admin文件夾下建立新的htaccess,很多坑爹的文章都沒有告訴你這一點,直接添加到網站根目錄下的那個htacess下的話……您要是想要自己的整個網站都只能自己訪問的話,不妨試試。 20.阻止某些IP訪問自己的網站(同第三條類似) 如果有些垃圾網站的Robot總是不停的抓取你網站的數據,你可以在htaccess中屏蔽掉這些IP。 - <Limit GET POST>
/ X& E) J: }2 t { - order allow,deny: Z) L* V" ^" ^
- deny from xx.xx.xx.xx
/ o h" B- o* {. O - allow from all9 u! l! l4 Z0 C6 F4 B/ m
- </Limit>
複製代碼類似的,更換一下deny和allow,可以實現只允許某些特定IP訪問自己的網站,當然如果您真的想要這麼做的話。 21.判斷瀏覽器 瀏覽器兼容可以說是前端工程師最為心痛的事。與其在css中寫各種hack,不如在htacess中判斷瀏覽器,直接指向不同的css文件。 - RewriteCond %{REQUEST_URI} index\.css*+ K( ~) e0 {9 K* y2 x7 m- g
- RewriteCond %{HTTP_USER_AGENT} "^Mozilla/4.0$"
. P3 ]; V) a( s: }; H. f! m8 M - RewriteRule ^(.*)$ http://domain.com/firefox.css
複製代碼類似的,利用htacess判斷訪問者是否持有的是移動設備也很容易。 - RewriteEngine on
3 i$ R6 S) U( J c B - RewriteCond %{HTTP_USER_AGENT} "Windows CE" [NC,OR]
* H8 C/ u+ z5 P: s - RewriteCond %{HTTP_USER_AGENT} "NetFront" [NC,OR]
6 A* ~* x# J. Y. g - RewriteCond %{HTTP_USER_AGENT} "Palm OS" [NC,OR]! [% F$ n( F1 C" r1 L Q
- RewriteCond %{HTTP_USER_AGENT} "Blazer" [NC,OR]' Z1 p7 @# d4 ^" F+ C9 j
- RewriteCond %{HTTP_USER_AGENT} "Elaine" [NC,OR]
* C+ {0 E2 K2 I' P6 m9 Z/ ^# I - RewriteCond %{HTTP_USER_AGENT} "^WAP.*$" [NC,OR]
( H* u' R8 u6 t6 i - RewriteCond %{HTTP_USER_AGENT} "Plucker" [NC,OR]
, I0 ]. H9 q* K - RewriteCond %{HTTP_USER_AGENT} "vodafone" [NC,OR]
# O, ?- J2 u3 W% f - RewriteCond %{HTTP_USER_AGENT} "iPhone" [NC,OR]* p' ]' [# }* K7 o0 D
- RewriteCond %{HTTP_USER_AGENT} "nokia" [NC,OR]3 B+ Z: a2 h4 H& F, {9 H# E" ~
- RewriteCond %{HTTP_USER_AGENT} "symbian" [NC,OR]
& I9 q" c; ~; B- Y% R ? - RewriteCond %{HTTP_USER_AGENT} "Opera Mini" [NC,OR]! M$ `1 M% Y) f7 m1 P% [
- RewriteCond %{HTTP_USER_AGENT} "BlackBerry" [NC,OR]
7 G1 a+ _' K- `( Y: w# n8 y, b - RewriteCond %{HTTP_USER_AGENT} "j2me" [NC,OR]+ l e9 q4 H h2 [+ i$ B
- RewriteCond %{HTTP_USER_AGENT} "midp" [NC,OR]0 \5 }- ]2 o a4 F
- RewriteCond %{HTTP_USER_AGENT} "htc" [NC,OR]. ~. a; J" o: z% s, K3 O4 ]; c: v
- RewriteCond %{HTTP_USER_AGENT} "java" [NC,OR]5 _$ ]: t G- x, h8 F* S
- RewriteCond %{HTTP_USER_AGENT} "sony" [NC,OR]
$ Q! B/ U$ g% a. _$ F: |& z - RewriteCond %{HTTP_USER_AGENT} "android" [NC,OR]
+ _1 g+ v' g3 Y9 \ - RewriteCond %{HTTP_USER_AGENT} "AvantGo" [NC]: G) T! ]" O/ Z0 F
- RewriteRule (.*) http://mobi.domain.com/ [R,L]
複製代碼還有通用的瀏覽器的USER_AGENT方式。有興趣的朋友可以去搜索一下。 22.禁止訪問特定的文件類型或文件 有些特定的文件、或某些文件,我們可能不想讓用戶訪問到,可以用如下代碼: - <Files secretfile.jpg>
# R6 Q. q" f3 t4 ]9 M @$ E - order allow,deny2 E2 ]+ K0 t- N; x1 ` `/ B1 s
- deny from all. k& u4 t' u4 Z# q- P: L
- </Files>
5 @( `6 t6 i" E3 R |8 Z8 e6 D, q - 7 B% w" p5 e I0 \3 _
- <FilesMatch ".(htaccess|htpasswd|ini|phps|fla|psd|log|sh)$">
: n' ?" B, d8 ^3 y: G - Order Allow,Deny
& J6 c& v/ J( {3 r4 m J5 V, e - Deny from all
0 ~, z A% C5 ]: f0 A - </FilesMatch>
複製代碼23.判斷瀏覽器的語言 想要根據瀏覽器的語言設定,跳轉到不同的頁面,可以用如下代碼: - RewriteCond %{HTTP:Accept-Language} ^zh-cn.*$ [NC]# i5 l- T4 h# J; r* w* y& X
- RewriteRule ^/?$ index_cn.htm [R=301,L]
複製代碼總結 就說到這裡了,其實htaccess的用途還有很多很多,大家可以根據上面的例子自己去挖掘htaccess的新的用途。不過注意修改htaccess時一定要小心,因為一但寫錯,很可能導致整個網站都無法訪問。
* G9 [0 ~: H* e# I2 C5 r9 m1 E% P7 j L% A6 b8 k
|