조회 수 65 추천 수 0 댓글 0

단축키

Prev이전 문서

Next다음 문서

단축키

Prev이전 문서

Next다음 문서

Extra Form

Apache 2.4 이상 버전에서 403 에러가 발생. error.log 를 보니 다음과 같은 에러가 있었다.

 

[Tue Dec 11 17:49:19.350384 2012] [authz_core:error] 
[pid 5308:tid 1576] [client 127.0.0.1:53603] AH01630: 
client denied by server configuration: /DOCUMENT_ROOT

 

 


아마도 우분투를 업그레이드하면서 (2.2에서 2.4로 업그레이드) 기존에쓰던 conf 파일 옵션값이 문제를 일으킨모양이다.

 

apache 2.2

<Directory /DOCUMENT_ROOT>

   ~~~

    Order allow,deny

    Allow from all

</Directory>

 

apache 2.4 최신

<Directory /DOCUMENT_ROOT>

    ~~~

    Require all granted

</Directory>

 

 

 

 

 

 

 

 

아래는 apache 공식사이트 설명문서다.

 

https://httpd.apache.org/docs/2.4/upgrading.html

 

 

 

 

2.2 configuration:

 Order deny,allow Deny from all 

2.4 configuration:

 Require all denied 

In this example, there is no authentication and all requests are allowed.

2.2 configuration:

 Order allow,deny Allow from all 

2.4 configuration:

 Require all granted 

In the following example, there is no authentication and all hosts in the example.org domain are allowed access; all other hosts are denied access.

2.2 configuration:

 Order Deny,Allow Deny from all Allow from example.org 

2.4 configuration:

 Require host example.org 

In the following example, mixing old and new directives leads to unexpected results.

Mixing old and new directives: NOT WORKING AS EXPECTED

 DocumentRoot "/var/www/html" <Directory "/"> AllowOverride None Order deny,allow Deny from all </Directory> <Location "/server-status"> SetHandler server-status Require local </Location> access.log - GET /server-status 403 127.0.0.1 error.log - AH01797: client denied by server configuration: /var/www/html/server-status 

Why httpd denies access to servers-status even if the configuration seems to allow it? Because mod_access_compat directives take precedence over the mod_authz_host one in this configuration merge scenario.

This example conversely works as expected:

Mixing old and new directives: WORKING AS EXPECTED

 DocumentRoot "/var/www/html" <Directory "/"> AllowOverride None Require all denied </Directory> <Location "/server-status"> SetHandler server-status Order deny,allow Deny from all Allow From 127.0.0.1 </Location> access.log - GET /server-status 200 127.0.0.1 

So even if mixing configuration is still possible, please try to avoid it when upgrading: either keep old directives and then migrate to the new ones on a later stage or just migrate everything in bulk.

In many configurations with authentication, where the value of the Satisfy was the default of ALL, snippets that simply disabled host-based access control are omitted:

2.2 configuration:

 # 2.2 config that disables host-based access control and uses only authentication Order Deny,Allow Allow from all AuthType Basic AuthBasicProvider file AuthUserFile /example.com/conf/users.passwd AuthName secure Require valid-user 

2.4 configuration:

 # No replacement of disabling host-based access control needed AuthType Basic AuthBasicProvider file AuthUserFile /example.com/conf/users.passwd AuthName secure Require valid-user 

In configurations where both authentication and access control were meaningfully combined, the access control directives should be migrated. This example allows requests meeting both criteria:

2.2 configuration:

 Order allow,deny Deny from all # Satisfy ALL is the default Satisfy ALL Allow from 127.0.0.1 AuthType Basic AuthBasicProvider file AuthUserFile /example.com/conf/users.passwd AuthName secure Require valid-user 

2.4 configuration:

 AuthType Basic AuthBasicProvider file AuthUserFile /example.com/conf/users.passwd AuthName secure <RequireAll> Require valid-user Require ip 127.0.0.1 </RequireAll> 

In configurations where both authentication and access control were meaningfully combined, the access control directives should be migrated. This example allows requests meeting either criteria:

2.2 configuration:

 Order allow,deny Deny from all Satisfy any Allow from 127.0.0.1 AuthType Basic AuthBasicProvider file AuthUserFile /example.com/conf/users.passwd AuthName secure Require valid-user 

2.4 configuration:

 AuthType Basic AuthBasicProvider file AuthUserFile /example.com/conf/users.passwd AuthName secure # Implicitly <RequireAny> Require valid-user Require ip 127.0.0.1 

0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
List of Articles
번호 분류 제목 글쓴이 조회 수 날짜
공지 뉴스 구글 최신 뉴스 file 덕후냥이 1460 2024.12.12
공지 일반 샤오미 BE6500 라우터 실사용 후기 (Wi-Fi 7 + 2.5G 스위치 기능까지 ㄷㄷ) 4 덕후냥이 1031 2025.06.28
공지 🚨(뉴비필독) 전체공지 & 포인트안내 22 무명의덕질 29157 2024.11.04
공지 URL만 붙여넣으면 끝! 임베드 기능 무명의덕질 23163 2025.01.21
6643 일반 메모리 용량 2배 늘어난 AMD ATI R9 290X 카라멜♥ 962 2014.11.07
6642 일반 메모리 용량 2배 늘어난 AMD ATI R9 290X 카라멜♥ 966 2014.11.07
6641 일반 최대 전송 1,733Mbps의 듀얼밴드 802.11ac 라우터 넷기어 "Nighthawk R7500" 카라멜♥ 1392 2014.11.07
6640 일반 최대 전송 1,733Mbps의 듀얼밴드 802.11ac 라우터 넷기어 "Nighthawk R7500" 카라멜♥ 1375 2014.11.07
6639 일반 AMD A시리즈 데스크탑 프로세서의 가격을 인하 카라멜♥ 918 2014.11.07
6638 일반 AMD A시리즈 데스크탑 프로세서의 가격을 인하 카라멜♥ 917 2014.11.07
6637 일반 카카오톡, 글로벌 이용자수 지속적 하락세 하루이나 1092 2014.11.08
6636 일반 카카오톡, 글로벌 이용자수 지속적 하락세 하루이나 1111 2014.11.08
6635 일반 MicroATX LGA2011v3 GIGABYTE GA-X99M-Gaming 5 출시 예정 코스모 972 2014.11.27
6634 일반 MicroATX LGA2011v3 GIGABYTE GA-X99M-Gaming 5 출시 예정 코스모 970 2014.11.27
6633 일반 GTX 960 2015년 1월 출시 소식 레종 690 2014.12.12
6632 일반 GTX 960 2015년 1월 출시 소식 레종 701 2014.12.12
6631 일반 Samsung SSD 850 EVO 선보여 레종 894 2014.12.12
6630 일반 Samsung SSD 850 EVO 선보여 레종 893 2014.12.12
6629 일반 ASUS GeForce GTX 980 Matrix Platinum 레종 687 2014.12.12
6628 일반 ASUS GeForce GTX 980 Matrix Platinum 레종 692 2014.12.12
6627 일반 AMD, 새로운 라인업 Fiji XT RADEONHD390X 사양 유출 3세대 908 2014.12.12
6626 일반 AMD, 새로운 라인업 Fiji XT RADEONHD390X 사양 유출 3세대 922 2014.12.12
6625 일반 ASUS "TUF '시리즈에서 화이트 컬러의 한정 모델"Sabertooth Z97 Mark S' 출시 3세대 931 2014.12.12
6624 일반 ASUS "TUF &#039;시리즈에서 화이트 컬러의 한정 모델"Sabertooth Z97 Mark S&#039; 출시 3세대 925 2014.12.12
Board Pagination Prev 1 2 3 4 5 ... 333 Next
/ 333