0

我试图拒绝访问 www-root 中的几个子目录(使用特定 url 时)。

我的目标是:

使 domain.com/subdir{1-3} 拒绝访问。

使 subdir{1-3}.domain.com 指向 %{DOCUMENT_ROOT}/subdir{1-3}。已经工作了。

我想将规则写入 httpd.conf 而不必使用 .htaccess 文件,并且如果可能的话,只使用一个目录部分。

这是我尝试过的:

<Directory "/var/www/subdir1">
  <IfModule rewrite_module>
    RewriteEngine on
    RewriteCond %{REQUEST_URI} ^/subdir1 [NC]
    RewriteRule ^.* - [F]
  </IfModule>
</Directory>

但是不行。

//E

得到它的工作,这就是我所做的:

<Directory />
  <IfModule mod_rewrite.c>
    RewriteEngine on
    RewriteCond %{REQUEST_URI} ^/subdir1/ [OR]
    RewriteCond %{REQUEST_URI} ^/subdir2/ [OR]
    RewriteCond %{REQUEST_URI} ^/subdir3/ [OR]
    RewriteCond %{REQUEST_URI} ^/subdir4/
    RewriteRule .* - [F]
  </IfModule>
</Directory>

我应该改变什么以使其更安全吗?

除了指向 ownclouds 根目录的 subdir3 之外,一切正常。一定和ownclouds自己的重写规则有关:

<IfModule mod_rewrite.c>
RewriteEngine on
RewriteRule .* - [env=HTTP_AUTHORIZATION:%{HTTP:Authorization}]
RewriteRule ^.well-known/host-meta /public.php?service=host-meta [QSA,L]
RewriteRule ^.well-known/host-meta.json /public.php?service=host-meta-json [QSA,L]
RewriteRule ^.well-known/carddav /remote.php/carddav/ [R]
RewriteRule ^.well-known/caldav /remote.php/caldav/ [R]
RewriteRule ^apps/calendar/caldav.php remote.php/caldav/ [QSA,L]
RewriteRule ^apps/contacts/carddav.php remote.php/carddav/ [QSA,L]
RewriteRule ^apps/([^/]*)/(.*\.(css|php))$ index.php?app=$1&getfile=$2 [QSA,L]
RewriteRule ^remote/(.*) remote.php [QSA,L]
</IfModule>

欢迎提示。

4

1 回答 1

0

尝试:

RewriteEngine On

RewriteCond %{HTTP_HOST} ^(www\.)?domain\.com$ [NC]
RewriteRule ^subdir1 - [L,F]
RewriteCond %{HTTP_HOST} ^subdir1\.domain\.com$ [NC]
RewriteCond %{REQUEST_URI} !^/subdir1/
RewriteRule ^(.*)$ /subdir1/$1 [L]

对于“subdir1”。

于 2013-11-08T10:10:11.257 回答