即使在.htaccess修改之后,也无法在Drupal中访问index.php

时间:2009-09-09 21:00:24

标签: php html drupal .htaccess drupal-6

我无法在Drupal安装的子目录中访问我的index.php文件。我可以访问其他子目录索引文件,我也可以访问该子目录,并在删除index.php文件时查看其内容。我已经对我的.htaccess文件进行了一段时间的更改,这应该允许访问任何index.html,index.php或index.htm文件。这是我的.htaccess文件,非常感谢任何帮助:


#
# Apache/PHP/Drupal settings:
#

# Protect files and directories from prying eyes.

  Order allow,deny


# Don't show directory listings for URLs which map to a directory.
Options -Indexes

# Follow symbolic links in this directory.
Options +FollowSymLinks

# Make Drupal handle any 404 errors.
ErrorDocument 404 /index.php

#Handle 401 errors manually
ErrorDocument 401 /401.html

# Force simple error message for requests for non-existent favicon.ico.

  # There is no end quote below, for compatibility with Apache 1.3.
  ErrorDocument 404 "The requested file favicon.ico was not found."


# Set the default handler.
DirectoryIndex index.php index.html index.htm
Options +Indexes

# Override PHP settings. More in sites/default/settings.php
# but the following cannot be changed at runtime.

# PHP 4, Apache 1.

  php_value magic_quotes_gpc                0
  php_value register_globals                0
  php_value session.auto_start              0
  php_value mbstring.http_input             pass
  php_value mbstring.http_output            pass
  php_value mbstring.encoding_translation   0


# PHP 4, Apache 2.

  php_value magic_quotes_gpc                0
  php_value register_globals                0
  php_value session.auto_start              0
  php_value mbstring.http_input             pass
  php_value mbstring.http_output            pass
  php_value mbstring.encoding_translation   0


# PHP 5, Apache 1 and 2.

  php_value magic_quotes_gpc                0
  php_value register_globals                0
  php_value session.auto_start              0
  php_value mbstring.http_input             pass
  php_value mbstring.http_output            pass
  php_value mbstring.encoding_translation   0


# Requires mod_expires to be enabled.

  # Enable expirations.
  ExpiresActive On

  # Cache all files for 2 weeks after access (A).
  ExpiresDefault A1209600

  # Do not cache dynamically generated pages.
  ExpiresByType text/html A1


# Various rewrite rules.

  RewriteEngine on

  # If your site can be accessed both with and without the 'www.' prefix, you
  # can use one of the following settings to redirect users to your preferred
  # URL, either WITH or WITHOUT the 'www.' prefix. Choose ONLY one option:
  #
  # To redirect all users to access the site WITH the 'www.' prefix,
  # (http://example.com/... will be redirected to http://www.example.com/...)
  # adapt and uncomment the following:
  # RewriteCond %{HTTP_HOST} ^example\.com$ [NC]
  # RewriteRule ^(.*)$ http://www.example.com/$1 [L,R=301]
  #
  # To redirect all users to access the site WITHOUT the 'www.' prefix,
  # (http://www.example.com/... will be redirected to http://example.com/...)
  # uncomment and adapt the following:
  # RewriteCond %{HTTP_HOST} ^www\.example\.com$ [NC]
  # RewriteRule ^(.*)$ http://example.com/$1 [L,R=301]

  # Modify the RewriteBase if you are using Drupal in a subdirectory or in a
  # VirtualDocumentRoot and the rewrite rules are not working properly.
  # For example if your site is at http://example.com/drupal uncomment and
  # modify the following line:
  # RewriteBase /drupal
  #
  # If your site is running in a VirtualDocumentRoot at http://example.com/,
  # uncomment the following line:
  # RewriteBase /

  # Rewrite URLs of the form 'x' to the form 'index.php?q=x'.
  RewriteCond %{REQUEST_FILENAME} !-f
  RewriteCond %{REQUEST_FILENAME} !-d
  RewriteCond %{REQUEST_URI} !=/favicon.ico
  RewriteRule ^(.*)$ index.php?q=$1 [L,QSA]



# $Id: .htaccess,v 1.90.2.3 2008/12/10 20:04:08 goba Exp $


2 个答案:

答案 0 :(得分:1)

Drupal 6还在系统创建的“files”目录中放置了一个非常严格的.htaccess文件。我刚做了一些测试,我可以在“files”目录中打开.html文件(加上图像和音频以及你通常在那里得到的所有内容)但不能打开.php文件。这适用于“文件”下的所有子文件夹。

我的系统上的行为与你所描述的不完全相符,但我打赌这是问题所在。

答案 1 :(得分:1)

你们不需要做任何事情 - 只需转到你将在drupal root director中获取的.htaccess并排除该文件或文件夹。

假设您想要排除此文件夹媒体的所有文件,请执行此操作

RewriteCond %{REQUEST_URI} !^/media/.*$

除非您知道自己要做什么,否则请不要使用Mod_security。

希望这有帮助。