apache禁止访问某个目录

本文介绍了一种禁止普通用户通过浏览器直接访问特定子目录的方法。通过修改Apache配置文件httpd.conf和httpd-vhosts.conf,设置<Directory>段内的Order deny,allow与Deny from all来阻止访问。最后重启Apache服务确保更改生效。

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

经常我们打开网站,在其后面添加一个目录名,就可以打开相应的代码文件,这个问题是亟待解决的。
然而,如何禁止访问该目录呢?

例如: ./test/admin
工程名: test目录
test目录下的子目录: admin
如何禁止普通用户打开网页访问 admin目录,即: http://www.***.com/admin禁止被打开。

解决办法:
1、从./conf/httpd.conf文件中,复制如下信息到虚拟主机的配置下:
<Directory />
Options FollowSymLinks
AllowOverride None
Order deny,allow
Deny from all
</Directory>

2、修改虚拟主机的配置文件./conf/extra/httpd-vhosts.conf。
NameVirtualHost *:80

<VirtualHost *:80>
DocumentRoot "D:/test"
ServerName www.***.com

[color=blue]
<Directory "D:/test/admin">
Options FollowSymLinks
AllowOverride None
Order deny,allow
Deny from all
</Directory>
[/color]

</VirtualHost>

3、重启apache服务,即可。
请测试: http://www.***.com/admin 禁止打开。
### 如何配置 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、付费专栏及课程。

余额充值