[linux] Apache VirtualHost 403 금지

최근에 Apache로 테스트 서버를 설정하려고했습니다. 사이트는 도메인 아래에서 실행되어야합니다 www.mytest.com. 항상 403 Forbidden오류가 발생합니다. 저는 Ubuntu 10.10 서버 에디션에 있습니다. 문서 루트는 dir 아래에 /var/www있습니다. 다음은 내 설정입니다.

/ var / www의 내용

ls -l /var/www/

total 12
drwxr-xr-x 2 root root 4096 2011-08-04 11:26 mytest.com
-rwxr-xr-x 1 root root 177 2011-07-25 16:10 index.html

서버의 호스트 파일 내용 (IP 192.168.2.5 사용)

cat /etc/hosts

127.0.0.1 localhost
127.0.1.1 americano
192.168.2.5 americano.mytest.com www.mytest.com

# The following lines are desirable for IPv6 capable hosts
::1 localhost ip6-localhost ip6-loopback
fe00::0 ip6-localnet
ff00::0 ip6-mcastprefix
ff02::1 ip6-allnodes
ff02::2 ip6-allrouters

사이트 구성

<VirtualHost *>
ServerAdmin admin@mytest.com
ServerName www.mytest.com
ServerAlias mytest.com

DocumentRoot "/var/www/mytest.com"

ErrorLog /var/log/apache2/mytest-error_log
CustomLog /var/log/apache2/mytest-access_log combined

#
# This should be changed to whatever you set DocumentRoot to.
#
<Directory "/var/www/mytest.com">
Options -Indexes FollowSymLinks
AllowOverride None

Order allow,deny
Allow from all
</Directory>
</VirtualHost>

.htaccess내 문서 루트에 파일 이 없습니다 . 권한이 올바르게 설정되었습니다 (www-data에서 읽을 수 있음).

데스크탑에서 IP 주소를 입력하면 사이트가 올바르게 표시됩니다. 내 데스크톱의 호스트 파일 www.mytest.com이 서버의 IP 를 가리 키 도록 변경했습니다 . 내가 그것을 사용하면 403. 이 사이트의 많은 기능은 사이트 이름에 민감하기 때문에 도메인 이름으로 사이트에 액세스 할 수 있어야합니다.

또 다른 펑키 한 점은 모든 로그 파일이 제대로 생성 되었더라도이 오류에 대한 정보가 없다는 것입니다.

나는 붙어있다. 아무도 도울 수 있습니까?



답변

Apache 2.4.3 (또는 약간 이전 버전)은 종종이 오류를 발생시키는 새로운 보안 기능을 추가했습니다. 또한 “서버 구성에 의해 클라이언트가 거부 됨”형식의 로그 메시지가 표시됩니다. 이 기능은 디렉토리에 액세스하려면 사용자 ID가 필요합니다. Apache와 함께 제공되는 httpd.conf의 DEFAULT에 의해 활성화됩니다. 지시문으로 기능 활성화를 볼 수 있습니다.

Require all denied

이것은 기본적으로 모든 사용자에 대한 액세스를 거부하는 것을 말합니다. 이 문제를 해결하려면 거부 된 지시문을 제거하거나 훨씬 더 나은 방법으로 액세스 권한을 부여하려는 디렉토리에 다음 지시문을 추가하십시오.

Require all granted

에서와 같이

<Directory "your directory here">
   Order allow,deny
   Allow from all
   # New directive needed in Apache 2.4.3:
   Require all granted
</Directory>


답변

아파치 우분투 2.4.7의 경우 마침내 apache2.conf에서 가상 호스트를 화이트리스트에 추가해야 함을 발견했습니다.

# access here, or in any related virtual host.
<Directory /home/gav/public_html/>
    Options FollowSymLinks
    AllowOverride None
    Require all granted
</Directory>


답변

권한 문제 일 수 있습니다.

가상 문서 루트에 대한 모든 단일 상위 경로는 웹 서버 httpd 사용자가 읽기, 쓰기 및 실행 가능해야합니다.

Apache 403 오류에 대한 이 페이지 에 따르면 .

을 사용 중이므로 Allow from all주문은 중요하지 않지만로 전환 Deny,Allow하여 기본 동작 을 ‘허용’ 으로 설정할 수 있습니다.


답변

Directory 절을 가상 호스트 밖으로 이동하고 가상 호스트를 선언하기 전에 넣으십시오.

오랫동안 나를 미치게 만들었습니다. 이유를 모릅니다. 데비안 일입니다.


답변

Ubuntu 14.04의 가상 호스트에서 동일한 문제가 발생했습니다.

나를 위해 다음 솔루션이 작동했습니다.

http://ubuntuforums.org/showthread.php?t=2185282

<Directory >태그를 추가하는 것입니다./etc/apache2/apache2.conf


답변

모든 것을 올바르게 수행했다면 다음과 같은 권한 홈 디렉토리를 제공하십시오.

sudo chmod o+x $HOME

그때

sudo systemctl restart apache2


답변

문제는 파일 접근 권한이 잘못되었다는 것입니다.

나는 디렉토리의 권한을 변경했고 작동했습니다.