禁止显示Apache目录列表-Indexes FollowSymLinks

本文详细介绍了如何通过修改Apache目录配置来禁止显示目录列表,包括全局禁用和针对特定目录的禁用方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


如何修改目录的配置以禁止显示 Apache 目录列表。
缺省情况下如果你在浏览器输入地址:

http://localhost:8080/
如果你的文件根目录里有 index.html,浏览器就会显示 index.html的内容,如果没有 index.html,浏览器就会显示文件根目录的目录列表,目录列表包括文件根目录下的文件和子目录。

同样你输入一个虚拟目录的地址:

http://localhost:8080/b/
如果该虚拟目录下没有 index.html,浏览器也会显示该虚拟目录的目录结构,列出该虚拟目录下的文件和子目录。

如何禁止 Apache 显示目录列表呢?

要禁止 Apache 显示目录结构列表,只需将 Option 中的 Indexes 去掉即可。

比如我们看看一个目录的目录配置:

<Directory "D:/Apa/blabla">
Options Indexes FollowSymLinks #---------->Options FollowSymLinks
AllowOverride None
Order allow,deny
Allow from all
</Directory>
你只需要将上面红色代码中的 Indexes 去掉,就可以禁止 Apache 显示该目录结构。用户就不会看到该目录下的文件和子目录列表了。

Indexes 的作用就是当该目录下没有 index.html 文件时,就显示目录结构,去掉 Indexes,Apache 就不会显示该目录的列表了。

第二种方法
解决办法:
1、编辑httpd.conf文件
vi ./conf/httpd.conf

找到如下内容:
……
<Directory “C:/Program Files/Apache2.2/htdocs”>
#
# Possible values for the Options directive are “None”, “All”,
# or any combination of:
Indexes Includes FollowSymLinks SymLinksifOwnerMatch ExecCGI MultiViews
#
# Note that “MultiViews” must be named *explicitly* — “Options All”
# doesn’t give it to you.
#
# The Options directive is both complicated and important. Please see
# http://httpd.apache.org/docs/2.2/mod/core.html#options
# for more information.
#
Options Indexes FollowSymLinks

#
# AllowOverride controls what directives may be placed in .htaccess files.
# It can be “All”, “None”, or any combination of the keywords:
# Options FileInfo AuthConfig Limit
#
AllowOverride None

#
# Controls who can get stuff from this server.
#
Order allow,deny
Allow from all

</Directory>
……

在Options Indexes FollowSymLinks在Indexes前面加上 – 符号。
即: Options -Indexes FollowSymLinks
【备注:在Indexes前,加 + 代表允许目录浏览;加 – 代表禁止目录浏览。】

这样的话就属于整个Apache禁止目录浏览了。

如果是在虚拟主机中,只要增加如下信息就行:
<Directory “D:\test”>
Options -Indexes FollowSymLinks
AllowOverride None
Order deny,allow
Allow from all
</Directory>
这样的话就禁止在test工程下进行目录浏览。

备注: 切记莫把“Allow from all”改成 “Deny from all”,否则,整个网站都不能被打开。
<Finished>

还有一种方法:

可以在根目录的 .htaccess 文件中输入

<Files *>
Options -Indexes
</Files>
就可以阻止Apache 将目录结构列表出来
### 如何配置 Apache 以访问指定目录 要实现对特定目录的访问控制,可以通过调整 Apache 的配置文件来完成。以下是具体的配置方法: #### 配置虚拟主机和目录权限 在 Apache 中,`<Directory>` 指令用于定义针对某个具体目录的行为。以下是一个典型的配置示例[^1]: ```apache <VirtualHost *:80> ServerName www.example.com DocumentRoot /var/www/example <Directory "/var/www/example"> Options Indexes FollowSymLinks AllowOverride All Require all granted </Directory> </VirtualHost> ``` 上述配置中: - `ServerName`: 定义服务器名称。 - `DocumentRoot`: 设置网站根目录的位置。 - `<Directory>` 块中的选项解释如下: - `Options Indexes FollowSymLinks`: 启用目录浏览功能并允许跟随符号链接[^2]。 - `AllowOverride All`: 允许 `.htaccess` 文件覆盖默认设置。 - `Require all granted`: 授予所有人对该目录的访问权限。 #### 禁止目录浏览 如果希望禁止用户查看目录结构,则可以移除 `Indexes` 或将其显式禁用。例如[^3]: ```apache <Directory "/var/www/example"> Options -Indexes FollowSymLinks AllowOverride All Require all granted </Directory> ``` 在此配置下,即使请求路径未指向任何索引文件(如 `index.html`),也不会显示目录列表而是返回 403 Forbidden 错误。 #### 控制 IP 地址访问 为了进一步增强安全性,还可以限制某些 IP 地址访问指定目录。例如,仅允许来自本地网络 (192.168.x.x) 的客户端访问[^5]: ```apache <Directory "/var/www/restricted"> Order deny,allow Deny from all Allow from 192.168. Require ip 192.168 </Directory> ``` 需要注意的是,在较新的 Apache 版本中可能需要替换旧版语法 (`Order`, `Deny`, `Allow`) 使用更现代的方式——即基于 `Require` 的指令集。 #### 测试与验证 完成以上更改之后,请记得重启 Apache 服务使新配置生效: ```bash sudo systemctl restart apache2 ``` 或者对于 CentOS/RHEL 用户而言可能是这样: ```bash sudo service httpd restart ``` 最后可通过浏览器尝试访问目标 URL 来确认一切正常运作。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值