4.0이상의 PHP에서 register_globals 문제

· 19년 전 · 2471
호스팅 서버 같은 곳에서 보안상의 이유로 register_globals 를 OFF 로 변경
하거나 또는 보안상 register_globals 를 OFF 로 변경하고 싶은데 기존의 소
스들 때문에 망설이시는 분들께 유용한 함수가 될것 같네요.

테스트 환경은 다음과 같이 하시면 이해가 쉬울 것 같습니다. 일단 php.ini
에서 register_globals = Off 로 설정을 한뒤에 아파치를 재시작 합니다. 다
음 간단하게 웹루트에 test_query.php 라는 스크립트를 하나 만듭니다.

--------- cut here test_query.php -----------
<?
function parse_query_str($level=0) {
# php.ini 의 register_globals 값을 확인한다.
# register_globals = OFF 일 경우만 작동.
if(ini_get("register_globals")) return;

# php 버젼이 4.1 보다 낮을 경우에는 함수 안에서 trackvar
# 를 사용하기 위해 global 로 지정해 줘야 한다.
if(substr(PHP_VERSION,0,3) < 4.1) {
global $HTTP_GET_VAR, $HTTP_POST_VARS;
if($level)
global $HTTP_COOKIE_VARS,$HTTP_SESSION_VARS,$HTTP_SERVER_VARS;
}

# 4.1 부터는 trackvars 에 대해 무조건 배열로 생성을 하기
# 때문에 is_array() 함수 보다는 count() 함수로 배열의 수를
# 체크한다.
if(count($HTTP_GET_VARS)) {
foreach($HTTP_GET_VARS as $key => $value) {
global ${$key};
${$key} = $value;
}
}

if(count($HTTP_POST_VARS)) {
foreach($HTTP_POST_VARS as $key => $value) {
global ${$key};
${$key} = $value;
}
}

if( $level && count($HTTP_COOKIE_VARS) ) {
foreach($HTTP_COOKIE_VARS as $key => $value) {
global ${$key};
${$key} = $value;
}
}

if( $level && count($HTTP_SESSION_VARS) ) {
foreach($HTTP_SESSION_VARS as $key => $value) {
global ${$key};
${$key} = $value;
}
}

if( $level && count($HTTP_SERVER_VARS) ) {
foreach($HTTP_SERVER_VARS as $key => $value) {
global ${$key};
${$key} = $value;
}
}
}

# POST, GET 만 제어한다.
parse_query_str();

echo "$a<br>n$b<br>n$c<br>n";

# POST, GET , COOKIE, SESSION, SERVER_var 를 모두 제어한다.
parse_query_str(1);
echo "$PHP_SELFn";
?>
--------- cut here test_query.php -----------

다음 http://domain.com/test_query.php 를 웹브라우져로 호출을 합니다. 결
과는 소스의 parse_query_str() 함수를 호출을 할 때와 안할 때의 차이를 보
시면 알겁니다.

위와 같이 이용을 하면 register_globals 의 값을 On 으로 두던 Off 로 두던
보안을 강화하면서 register_globals 의 값에 상관없이 register_globals 의
값이 On 일때 처럼 코딩을 할 수 있게 됩니다.

이 함수가 보안을 위하여 register_globals 의 값을 Off 로 두는것에 어떠한
작용을 하게 될지에 대해서는 검증이 되지는 않았습니다만 일단 넘어오는 값
을 GET 이면 GET 으로 넘어온 값을 조절하고 POST 이면 POST 의 값을 조절하
기 때문에 크게 위배되지는 않을것 같습니다.

원래는 GET 과 POST 로 넘어오는 값을 하나의 배열로 return 하는 방법이 더
낳을것 같지만 그렇게 되면 기존의 소스를 너무 수정을 해야 하기 때문에 위
와 같은 식으로 전역 변수화 처리를 한 것입니다. ^^;
==========================================================================
이번에 외국 서버에 사이트 이전 작업하다가 이문제로 무지 고생했네요.
고생고생 해서 해결한 만큼 좋은 경험 한것두 같습니다.
참 저같은 경우는 적용이 안되었습니다.^^;;;;

출저 : koreaPHP tip&tech<div class='small'>[이 게시물은 관리자님에 의해 2011-10-31 17:12:10 PHP & HTML에서 이동 됨]</div>
|
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

태그 필터 (최대 3개) 전체 개발자 소스 기타 mysql 팁자료실 javascript php linux flash 정규표현식 jquery node.js mobile 웹서버 os 프로그램 강좌 썸네일 이미지관련 도로명주소 그누보드5 기획자 견적서 계약서 기획서 마케팅 제안서 seo 통계 서식 통계자료 퍼블리셔 html css 반응형 웹접근성 퍼블리싱 표준화 반응형웹 홈페이지기초 부트스트랩 angularjs 포럼 스크린리더 센스리더 개발자톡 개발자팁 퍼블리셔톡 퍼블리셔팁 기획자톡 기획자팁 프로그램강좌 퍼블리싱강좌
+
제목 글쓴이 날짜 조회
19년 전 조회 2,654
19년 전 조회 3,694
19년 전 조회 6,155
19년 전 조회 4,053
19년 전 조회 3,235
19년 전 조회 2,311
19년 전 조회 2,594
19년 전 조회 2,373
19년 전 조회 2,492
19년 전 조회 2,584
19년 전 조회 3,027
19년 전 조회 2,706
19년 전 조회 2,164
19년 전 조회 3,310
19년 전 조회 3,763
19년 전 조회 4,015
19년 전 조회 3,498
19년 전 조회 3,554
19년 전 조회 2,748
19년 전 조회 2,650
19년 전 조회 2,653
19년 전 조회 2,505
19년 전 조회 2,748
19년 전 조회 4,034
19년 전 조회 3,835
19년 전 조회 2,259
19년 전 조회 2,195
19년 전 조회 1,722
19년 전 조회 4,052
19년 전 조회 6,073
19년 전 조회 7,173
19년 전 조회 2,655
19년 전 조회 2,879
19년 전 조회 4,362
19년 전 조회 2,352
19년 전 조회 3,777
19년 전 조회 3,065
19년 전 조회 2,904
19년 전 조회 2,386
19년 전 조회 2,666
19년 전 조회 2,761
19년 전 조회 3,273
19년 전 조회 3,928
19년 전 조회 3,443
19년 전 조회 2,968
19년 전 조회 2,460
19년 전 조회 3,120
19년 전 조회 3,227
19년 전 조회 2,745
19년 전 조회 2,472
19년 전 조회 3,507
19년 전 조회 5,048
19년 전 조회 5,254
19년 전 조회 2,483
19년 전 조회 2,369
19년 전 조회 5,166
19년 전 조회 9,160
19년 전 조회 2,241
19년 전 조회 5,108
19년 전 조회 4,548
19년 전 조회 2,803
19년 전 조회 5,157
19년 전 조회 2,982
19년 전 조회 3,874
19년 전 조회 2,797
19년 전 조회 3,623
19년 전 조회 2,142
19년 전 조회 5,560
19년 전 조회 1,909
19년 전 조회 6,256
19년 전 조회 3,063
19년 전 조회 6,236
19년 전 조회 7,012
19년 전 조회 3,916
19년 전 조회 2,400
19년 전 조회 2,281
19년 전 조회 7,069
19년 전 조회 2,573
19년 전 조회 4,130
19년 전 조회 5,523
19년 전 조회 2,850
19년 전 조회 1,902
19년 전 조회 1,747
19년 전 조회 1,699
19년 전 조회 1,971
19년 전 조회 1,982
19년 전 조회 1,976
19년 전 조회 1,891
19년 전 조회 2,690
19년 전 조회 2,510
19년 전 조회 3,648
19년 전 조회 2,779
19년 전 조회 2,747
19년 전 조회 3,591
19년 전 조회 4,803
19년 전 조회 3,148
19년 전 조회 2,991
19년 전 조회 3,526
19년 전 조회 6,461
19년 전 조회 2,373