Page

[apache]设置apache的httpd.conf禁止直接访问网站的目录

621Anson16-07-22


apache默认如果目录没有index文件则显示整个目录出来,但是直接把网站的目录暴露给别人是非常危险的事情,我们可以通过配置apache的httpd.conf文件禁止别人这样做。

首先:


进入apache的httpd.conf文件,ctrl+f查找,将

Options +indexes +FollowSymLinks去掉+indexes


不同的apache版本写法可能不太一样,有些是没有+号的。


blob.png





配置好的效果就是:


blob.png

默认没有配置则会显示整个目录:


blob.png

别人可以看到目录下的其他文件,还可以下载,这对网站来说是非常危险的。




配置好的apache需要目录下有index文件才会显示:


blob.png


blob.png





以下是更加具体的自定义配置


1. 禁止访问某些文件/目录
增加Files选项来控制,比如要不允许访问 .inc 扩展名的文件,保护php类库:
<Files ~ ".inc$">
Order allow,deny
Deny from all
</Files>

禁止访问某些指定的目录:(可以用 <DirectoryMatch>   来进行正则匹配)
<Directory ~ "^/var/www/(.+/)*[0-9]{3}">
Order allow,deny
Deny from all
</Directory>

通过文件匹配来进行禁止,比如禁止所有针对图片的访问:
<FilesMatch .(?i:gif|jpe?g|png)$>
Order allow,deny
Deny from all
</FilesMatch>

针对URL相对路径的禁止访问:
<Location /dir/>
Order allow,deny
Deny from all
</Location>




来自ansion博客

2016年7月22日