|
|
apache禁止访问目录列表4 u/ j( ^% P& y/ Q( P
apache禁止访问目录列表对于开发人员来说还是蛮实用的,可以迅速查找根目录下的所有项目,但如果一个挂在互联网上的服务器为了提高安全性就必须禁止访问目录列表。
: l, Y8 r5 e0 S7 u5 S% K& v) N& a1 {, j0 M: U( F
找到Apache 的 httpd.conf 配置文件将:. Z6 z6 K( E0 _5 E. h) j, w3 ]# ?
l( `# I" s+ n
" r& t" Z) X3 a; }( u& n6 [
XML/HTML代码- ?9 \. P) [. K- _- b6 d1 g
Options Indexes FollowSymLinks 改为:Options FollowSymLinks 也就是把 Indexes 去掉。 / U4 v1 [: }, }7 k. A
1 A/ Q4 S8 G$ K4 L
额外信息:在apache中设置虚拟主机
& _1 _7 }3 W: A+ Y2 \& ~8 d7 [; Y
|9 s" P3 M& K* j0 A1 h# x( W 在IIS中我们可以方便的通过不同的IP或者端口再或者主机头来设置虚拟主机,在apache中也一样可以。6 a; P: w) T7 \: n# f: R3 W
假设有www.123.com和www321.com两个域名,要同时指向一个服务器地址,通过这两个域名访问时,要呈现不同的内容,那就需要设置虚拟主机了。域名设置虚拟主机还需要DNS服务器的支持。
# e. y* H2 l8 Z7 r. k0 O
0 T8 T- P, y: c% a配置常识:
2 x( B9 Z8 T* r9 P2 [. M1 {1 k( \
#Vi /etc/apache/httpd.conf #按你实际情况选择
. |! }0 G! Z" q0 g4 m0 \
Z' M% A' m+ x( j+ _* r" ^+ g; w* A namevirtualhost * #设定虚拟主机ip默认任意9 ^) v$ B0 Z2 ?5 f8 E
" M! {* l5 I3 i; s9 N+ H( L#一个简单的例子
# l8 p8 w, x2 f- `' N: z< VirtualHost *> #设置一个虚拟主机 设置其ip默认任意: ]+ k* W3 D8 r- V& X/ `; o
ServerName www.123.com #设置用那个域名访问
' u" v4 I" G5 `7 h; j, }( sDocumentRoot /var/www/nckz.org #设置这个虚拟主机web存放的目录 * c9 b; |5 R' N* a$ B- i4 T6 z
</VirtualHost>
# @0 B2 R5 w6 x6 k7 p; K0 ?9 ]0 D
; ^! L- X" [: Z5 }* u2 X#配置参数说明: K0 ~6 a, F$ E8 W, h
<VirtualHost *> #设置一个虚拟主机 设置其ip默认任意9 |' i0 Q/ J8 l3 p( e; L
ServerAdmin webmaster@site1.com #设置管理员邮箱
! p$ P+ J5 E& D( ? DocumentRoot "f:/kuaipan" #设置虚拟主机网站目录
0 K: p* [6 ]& { ServerName qqcm.net #设置主域名
' c. c! ?% }& y7 ^. C. I( v ServerAlias fcc.net #设置别名# x& v K N6 q; v4 e
ErrorLog "logs/site1-error.log" #设置错误日志路径
( a+ r$ ]; i& q8 }7 J$ y CustomLog "logs/site1-access.log" combined #设置错误日志路径和方式( A9 e, `, m# J
, }: m4 `5 w9 f" g! n& L4 E) C
<Directory f:/kuaipan> #网站目录权限相关针对本虚拟主机,请注意执行规则,不要的选项去掉' f, i* x% [3 B( W' s$ x2 \
Options Indexes FollowSymLinks
4 d- K/ V: r0 E$ N! W. ?& D DirectoryIndex index.html index.php #设置默认索引文件(主页)
, Q. Q% ]6 t* h, X5 @: l AllowOverride all #确定允许存在于.htaccess文件中的指令类型,默认全部5 _0 l$ P8 ?0 d& f& ^" n i
Order allow,deny #先检查允许设定,没有允许的全部禁止,allow,deny可对换
" M6 T. |( g, F* _4 ~5 [" @( f Deny from 10.0.0.1 #禁止10.0.0.1这个ip访问
B- K4 K* n' s( i Allow from all #允许所有ip和域名访问
) h# S# J p; G, V</Directory>- e% \( R6 ^- }4 e& t! e
! o" r7 X: K; X2 M: t0 r/ Y
</VirtualHost>0 U, Z( V* g/ B- D6 H# C1 S
. Q- w' t V5 K: t1 Vapache禁止使用IP访问的实现方法
& m/ y( \' B! D v2 l用apache搭建的WEB服务器,如何让网友只能通过设定的域名访问,而不能直接通过服务器的IP地址访问呢,有两个方法可以实现(仅限于我知道的,当然肯定还会有其他方法可以实现),都是修改httpd.conf文件来实现的,下面举例说明。 方法一:在httpd.conf文件最后面,加入以下代码
5 I, [: M, `- | k0 b5 L NameVirtualHost 221.*.*.*( M" n9 M8 z7 _6 z- R5 [
<VirtualHost 221.*.*.*>; P5 y( O% |( { }
ServerName 221.*.*.*
+ y3 ?! a- U9 ^0 J z# A* o <Location />$ F: v5 C, S) C H% g- W
Order Allow,Deny; e9 q) Z- O& F) d8 f
Deny from all
. U* M1 ], q2 j5 Z" v </Location>7 E3 x" T! k% M! R8 c n0 E
</VirtualHost> $ |) q- Z0 h* u. V2 c- w6 K# `
<VirtualHost 221.*.*.*>
9 h7 ~% ^" D1 o: ]; ^ DocumentRoot "c:/web"$ p9 [0 h0 _* s/ [2 R
ServerName www.webjx.com u o) H; o' I* H
</VirtualHost>
, ?' E/ m' ]1 E4 O% D 说明:蓝色部分是实现拒绝直接通过221.*.*.*这个IP的任何访问请求,这时如果你用221.*.*.*访问,会提示拒绝访问。红色部分就是允许通过www.webjx.com这个域名访问,主目录指向c:/web(这里假设你的网站的根目录是c:/web)
# N+ x% D0 X9 D3 \* F: F 方法二:在httpd.conf文件最后面,加入以下代码
1 s" y4 u' `7 D NameVirtualHost 221.*.*.*
* O5 X( k1 \: q- v/ ?: m <VirtualHost 221.*.*.*>7 z+ V0 x z8 K* P+ c, M
DocumentRoot "c:/test"
) Z G4 t+ t+ Y! a, [/ e% c8 E ServerName 221.*.*.*' v4 I) l* W0 k
</VirtualHost> 6 p& G7 r3 c+ Z% Y1 F: ]
<VirtualHost 221.*.*.*>
: ?; E7 x. ?; u% { DocumentRoot "c:/web"
" M7 z1 j; B3 ], ~: E ServerName www.webjx.com4 {" w" f2 S( c5 i
</VirtualHost> - C! R9 s4 }4 v
* t2 m% F |3 n: E& U
说明:蓝色部分是把通过221.*.*.*这个IP直接访问的请求指向c:/test目录下,这可以是个空目录,也可以在里面建一个首页文件,如index.hmtl,首面文件内容可以是一个声明,说明不能通过IP直接访问。红色部分的意思跟方法一是一样的。! K2 T9 n0 q- ^1 ^6 ~
- [/ @( s: l: L% t6 A" T5 b) \
- u) A4 Q; s3 k, Y! {- s7 o2. 禁止某些IP访问/只允许某些IP访问 : M. f! h" h4 F: R2 C
如果要控制禁止某些非法IP访问,在Directory选项控制: ( k8 N; m; L, S: S
/ T. o/ r- |& r
Order allow,deny 2 Y" a) Y2 e8 k$ s6 v" e* _) s2 z
Allow from all & }! O$ k7 t: D3 K% s7 F& e1 Z
Deny from 10.0.0.1 #阻止一个IP
" n7 j# a* j% A Deny from 192.168.0.0/24 #阻止一个IP段 - }! X! a; O$ |( W6 Y/ S
+ T/ l' j6 P* R) _* S* C' W% I4 [
9 K& b8 Z+ p' o* [$ `4 I只允许某些IP访问,适合比如就允许内部或者合作公司访问:
) ]2 E% A7 B2 O* k/ B, f) X. y/ I, ?/ X" w
Order deny,allow
8 I1 a. Z" K+ Y( H% _ Deny from all 4 }, h( ~; v; S2 D) V
All from example.com #允许某个域名 ) K" r! d# y O8 k+ a. l
All from 10.0.0.1 #允许一个iP , Q' p+ ?7 p: i* @
All from 10.0.0.1 10.0.0.2 #允许多个iP
/ D' }2 a/ D- A, ^9 U0 c8 S Allow from 10.1.0.0/255.255.0.0 #允许一个IP段,掩码对 & A* i- n! s e: |
All from 10.0.1 192.168 #允许一个IP段,后面不填写
% S: S d. V: R8 `$ D" sAll from 192.168.0.0/24 #允许一个IP段,网络号
& F" l0 p, t+ k0 N9 z$ R! h. b 注:修改后要重启apache
6 f1 t1 M g9 }0 N6 P |
|