使用 .htaccess 文件禁用 Web 目录列举

简介:

确保 Apache web 服务器安全 是最重要的任务之一,特别是在你的网站刚刚搭建好的时侯。

比方说,如果你 Apache 服务目录 (/var/www/tecmint 或 /var/www/html/tecmint) 下创建一个名为tecmint 的目录,并且忘记在该目录放置 index.html,你会惊奇的发现所有访问者都可以在浏览器输入  来完整列举所有在该目录中的重要文件和文件夹。

本文将为你展示如何使用 .htaccess 文件禁用或阻止 Apache 服务器目录列举。

以下便是不存在 index.html ,且未采取防范措施前,目录的列举的情况。

[Apache 目录列举][4]

Apache 目录列举

首先,.htaccess  (hypertext access) 是一个文件,它可以让站点管理员控制服务器的环境变量以及其他的重要选项,用以增强他/她的站点功能。

欲知更多关于该重要文件的信息,请阅读以下文章,以便通过 .htaccess 的方法来确保 Apache Web 服务器的安全。

  1. 确保 Apache Web 服务器安全的 25 条 .htaccess 设置技巧
  2. 使用 .htaccess 为 Apache Web 目录进行密码保护

使用这一简单方法,在站点目录树中的任意/每个目录创建 .htaccess 文件,以便为站点根目录、子目录和其中的文件提供保护支持。

首先要 Apache 主配置文件中为你的站点启用 .htaccess 文件支持。

 
  1. $ sudo vi /etc/apache2/apache2.conf #Debian/Ubuntu 系统
  2. $ sudo vi /etc/httpd/conf/httpd.conf #RHEL/CentOS 系统

然后寻找以下部分,其中 AllowOverride 指令必须设置为 AllowOverride All

 
  1. /var/www/html/>
  2. Options Indexes FollowSymLinks
  3. AllowOverride All

如果已存在 .htaccess 文件,先备份(如下),假设文件在 /var/www/html/tecmint/ (并要禁用该目录列举):

 
  1. $ sudo cp /var/www/html/tecmint/.htaccess /var/www/html/tecmint/.htaccess.orig

然后你就可以在某个特定的目录使用你喜欢的编辑器打开 (或创建) 它,以便修改。并添加以下内容来关闭目录列举。

 
  1. Options -Indexes

下一步就是重启 Apache Web 服务器:

 
  1. -------- 使用 SystemD 的系统 --------
  2. $ sudo systemctl restart apache2
  3. $ sudo systemctl restart httpd
  4. -------- 使用 SysVInit 的系统 --------
  5. $ sudo /etc/init.d/apache2 restart
  6. $ sudo /etc/init.d/httpd restart

现在来验证效果,在浏览器中输入:,你会得到类似如下的信息:

[Apache 目录列举已禁用][5]

Apache 目录列举已禁用

在本文中,我们描述了如何使用 .htaccess 文件来禁用 Apache Web 服务器的目录列举。之后我们会介绍两种同样简单的我方法来实现这一相同目的。随时保持联系。

原文发布时间为:2017-02-10

本文来自云栖社区合作伙伴“Linux中国”

相关文章
|
6月前
|
安全 内存技术
【文件上传-配置文件】crossdomain.xml跨域策略配置文件上传
【文件上传-配置文件】crossdomain.xml跨域策略配置文件上传
|
8月前
Web 目录文件浏览配置
Web 目录文件浏览配置
58 1
|
10月前
|
XML 开发框架 .NET
【已解决】请在位于当前 Web 应用程序根目录下的“web.config”配置文件中创建一个 <customErrors> 标记
【已解决】请在位于当前 Web 应用程序根目录下的“web.config”配置文件中创建一个 <customErrors> 标记
|
11月前
|
运维 Linux Apache
LAMP架构调优(十)——Apache禁止指定目录PHP解析与错误页面优化
LAMP架构调优(十)——Apache禁止指定目录PHP解析与错误页面优化
308 2
|
11月前
|
存储 中间件
13_文件上传&静态目录
13_文件上传&静态目录
195 0
|
应用服务中间件 nginx
nginx配置web访问以及查看目录文件
nginx 配置web和文件目录结构
6612 0
|
应用服务中间件 nginx
AMH面板伪静态Rewrite文件存放路径目录
AMH面板开启URL重写规则后,可以自定义伪静态规则,那么,AMH面板的Rewrite文件存放在哪?云吞铺子分享AMH面板伪静态Rewrite文件存放路径目录: AMH伪静态Rewrite文件存放路径 Rewrite存放文件夹:/usr/local/nginx/conf/rewrite AMH伪静态Rewrite文件是以.conf结尾的文件,AMH面板默认只有amh.conf这一个配置文件,我们可以vi自行配置伪静态规则文件(AMH主机面板伪静态规则大全),然后在Rewrite规则中启用。
1019 0
Confluence 6 WebDAV 禁用严格路径检查
如果你在你的 WebDAV 客户端发现了一些不正常的现象,例如文件夹在 Confluence 中是存在的,但是在你客户端下载的文件中就不存在了。
1131 0
下一篇
oss创建bucket