그누보드 최신버전 (5.0.36) 살펴보기 - common.php (2)
common.php 그누보드에서 가장 기본이 되는 파일이라고 볼수 있습니다.
모든 파일에 기본적으로 인클루드 되어서 사용됩니다.
에러출력 설정, 보안적인 처리, 기본적인 경로 설정, 디비연결, 세션 설정및 시작, 공용변수의 초기화 및 재설정, 기타 확장 등의 내용으로 이루어져 있습니다.
function g5_path()
{
$result['path'] = str_replace('\\', '/', dirname(__FILE__));
$tilde_remove = preg_replace('/^\/\~[^\/]+(.*)$/', '$1', $_SERVER['SCRIPT_NAME']);
$document_root = str_replace($tilde_remove, '', $_SERVER['SCRIPT_FILENAME']);
$root = str_replace($document_root, '', $result['path']);
$port = $_SERVER['SERVER_PORT'] != 80 ? ':'.$_SERVER['SERVER_PORT'] : '';
$http = 'http' . ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS']=='on') ? 's' : '') . '://';
$user = str_replace(str_replace($document_root, '', $_SERVER['SCRIPT_FILENAME']), '', $_SERVER['SCRIPT_NAME']);
$host = isset($_SERVER['HTTP_HOST']) ? $_SERVER['HTTP_HOST'] : $_SERVER['SERVER_NAME'];
if(isset($_SERVER['HTTP_HOST']) && preg_match('/:[0-9]+$/', $host))
$host = preg_replace('/:[0-9]+$/', '', $host);
$result['url'] = $http.$host.$port.$user.$root;
return $result;
}
"g5_path" 함수는 기본적으로 현재 접속한 url 과 common.php 의 파일 전체 경로로 부터 그누보드가 설치된 기본 url 과 기본 path 를 구해 내는 함수입니다.
__FILE__ 은 현재 파일, 즉 common.php 의 절대 경로를 의미 하는 상수 입니다.
http://php.net/manual/kr/language.constants.predefined.php
dirname 인자로 들어온 경로의 상위 디렉토리 까지의 경로를 반환합니다.
http://php.net/manual/kr/function.dirname.php
만약, "/home/계정/public_html/g5" 에 그누보드를 설치하였다면
__FILE__ 은 "/home/계정/public_html/g5/common.php" 가 되고
dirname(__FILE__) 은 "/home/계정/public_html/g5" 가 됩니다.
str_replace('\\', '/', dirname(__FILE__));
윈도우서버인 경우 DIRECTORY_SEPARATOR (디렉토리 구분자) 가 \(back slash) 이기 때문에 전부 / 로 맞춰주기 위한 부분입니다.
이 부분을 조금 고친다면
if (DIRECTORY_SEPARATOR !== '/')
$result['path'] = str_replace(DIRECTORY_SEPARATOR, '/', dirname(__FILE__));
정도로 할수 있을것 같습니다.
$result['path'] 은 그누보드가 설치된 절대 경로 ("/home/계정/public_html/g5") 입니다.
$tilde_remove = preg_replace('/^\/\~[^\/]+(.*)$/', '$1', $_SERVER['SCRIPT_NAME']);
는 좀 알아보기 쉽게 변경해 보겟습니다.
$tilde_remove = preg_replace('`^/~[^/]+(.*)$`', '$1', $_SERVER['SCRIPT_NAME']);
받은 문자열이 /~ 로 시작하고 /가 아닌 문자열이 온다음 /를 포함한 기타문자열이 있거나 없을때
그 문자열 전체를 "/를 포함한 기타문자열" 로 치환하겠다 라는 의미입니다.
보통은 "http://도메인/g5/index.php" 와 같이 접속하지만,
아파치 설정에 따라 "http://아이피/~계정/g5/index.php" 와 같이 접속되는 경우가 있습니다.
(정확한 명칭은 생각나지 않습니다.)
그런 경우에 $_SERVER['SCRIPT_NAME'] 은 "/~계정/g5/index.php" 과 같은 값을 가지고 있으므로, 그것을 "/g5/index.php" 으로 바꾸겠다는 의미입니다.
일반적인 "http://도메인/g5/index.php" 형태의 접속이라면 $_SERVER['SCRIPT_NAME'] 은 "/g5/index.php" 입니다.
즉, 동일하게 바꿔주는 것입니다.
$document_root = str_replace($tilde_remove, '', $_SERVER['SCRIPT_FILENAME']);
이것 역시,
"http://도메인/g5/index.php" 형태로 접속하면, $_SERVER['DOCUMENT_ROOT'] 는 "/home/계정/public_html" 이지만,
"http://아이피/~계정/g5/index.php" 형태로 접속하면, $_SERVER['DOCUMENT_ROOT'] 는 아파치 설정상 기본 웹의 document_root 를 반환하게 됩니다.
즉, 일치하지 않는 경우가 발생합니다.
그래서, 이것도 동일하게 맞추어 주기 위해서 위와 같은 코드가 포함된 것입니다.
$_SERVER['SCRIPT_FILENAME'] 는 현재 실행된 파일의 전체 경로("/home/계정/public_html/g5/index.php") 이므로, 거기서 "/g5/index.php" 을 제거함으로서 "/home/계정/public_html" 와 같이 됩니다.
결론적으로, 어떻게 접속했던 document_root 를 동일하게 뽑기 위한 과정이라고 이해하시면 될 것 같습니다.
$root = str_replace($document_root, '', $result['path']);
"/home/계정/public_html/g5" 에서 "/home/계정/public_html" 제거함으로써 "/g5" 만 남게됩니다.
만약, 설치를 "/home/계정/public_html" 에 하였다면 $root 는 "" 만 남게 됩니다.
그러니까 $root 는 $document_root 에서 어디에 설치하였는가를 나타내는 변수입니다.
$port = $_SERVER['SERVER_PORT'] != 80 ? ':'.$_SERVER['SERVER_PORT'] : '';
이것은 웹서버의 포트가 80번이 아니면 포트를 따로 저장한다는 뜻입니다.
$http = 'http' . ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS']=='on') ? 's' : '') . '://';
접속환경이 보안서버인지 아닌지 판단하는 부분입니다.
$user = str_replace(str_replace($document_root, '', $_SERVER['SCRIPT_FILENAME']), '', $_SERVER['SCRIPT_NAME']);
"/home/계정/public_html/g5/index.php" 에서 "/home/계정/public_html" 를 제거 하고 ("/g5/index.php")
"http://도메인/g5/index.php" 형태로 접속하면, $_SERVER['SCRIPT_NAME'] 이 "/g5/index.php"" 이고, 거기서 위에서 뽑은 "/g5/index.php" 제거하면 "" 만 남게 됩니다.
"http://아이피/~계정/g5/index.php" 형태로 접속하면, $_SERVER['SCRIPT_NAME'] 이 "/~계정/g5/index.php"" 이고, 거기서 위에서 뽑은 "/g5/index.php" 제거하면 "/~계정" 만 남게 됩니다.
$host = isset($_SERVER['HTTP_HOST']) ? $_SERVER['HTTP_HOST'] : $_SERVER['SERVER_NAME'];
접속호스트를 뽑습니다.
"http://도메인/g5/index.php" 형태로 접속하면, "도메인" 이고
"http://아이피/~계정/g5/index.php" 형태로 접속하면, "아이피" 입니다.
if(isset($_SERVER['HTTP_HOST']) && preg_match('/:[0-9]+$/', $host))
$host = preg_replace('/:[0-9]+$/', '', $host);
뽑혀진 호스트에 :8080 같은 포트 가 붙어 있으면 제거하는 부분입니다.
$result['url'] = $http.$host.$port.$user.$root;
설치된 그누보드의 기본 주소를 뽑습니다.
"http://도메인/g5/index.php" 형태로 접속하면, "http://" . "도메인" . "" . "" . "/g5";
"http://도메인:8080/g5/index.php" 형태로 접속하면, "http://" . "도메인" . ":8080" . "" . "/g5";
"http://아이피/~계정/g5/index.php" 형태로 접속하면, "http://" . "아이피" . "" . "/~계정" . "/g5";
"http://아이피:8080/~계정/g5/index.php" 형태로 접속하면, "http://" . "아이피" . ":8080" . "/~계정" . "/g5";
$g5_path = g5_path();
g5_path() 를 실행하여 설치된 그누보드의 전체경로 $g5_path['path'] 와 설치된 그누보드의 기본 주소 $g5_path['url'] 을 뽑습니다.
include_once($g5_path['path'].'/config.php'); // 설정 파일
이전 내용에서 다루었듯이
http://sir.co.kr/bbs/board.php?bo_table=pg_lecture&wr_id=562
if (G5_DOMAIN) {
define('G5_URL', G5_DOMAIN);
} else {
if (isset($g5_path['url']))
define('G5_URL', $g5_path['url']);
else
define('G5_URL', '');
}
if (isset($g5_path['path'])) {
define('G5_PATH', $g5_path['path']);
} else {
define('G5_PATH', '');
}
와 같이 사용 됩니다.
unset($g5_path);
상수로 만들엇기때문에 더이상 필요없는 변수 이므로 없애줍니다.
댓글 8개
1~3강까지 속전속결로...
역시 전 선생님의 수제자가 될 자질이 충분한가 봅니다. (__)
착실하시네요 ㅎㅎ
깊으신 사랑과 노고.. 고맙습니다. 선생님
고맙습니다..
고맙습니다.
감사합니다.
게시판 목록
프로그램
| 번호 | 제목 | 글쓴이 | 날짜 | 조회 |
|---|---|---|---|---|
| 530 |
|
19년 전 | 1231 | |
| 529 |
|
19년 전 | 1413 | |
| 528 |
|
19년 전 | 1978 | |
| 527 |
사랑과우정
|
19년 전 | 2389 | |
| 526 | 19년 전 | 2870 | ||
| 525 |
|
19년 전 | 2294 | |
| 524 |
|
19년 전 | 1799 | |
| 523 | 19년 전 | 7037 | ||
| 522 |
|
19년 전 | 3729 | |
| 521 | 19년 전 | 2338 | ||
| 520 | 19년 전 | 2375 | ||
| 519 | 19년 전 | 2868 | ||
| 518 |
|
19년 전 | 5780 | |
| 517 |
|
19년 전 | 5554 | |
| 516 |
|
19년 전 | 2260 | |
| 515 |
|
19년 전 | 3294 | |
| 514 | 19년 전 | 2865 | ||
| 513 | 19년 전 | 2217 | ||
| 512 |
개발자관리자
|
19년 전 | 2728 | |
| 511 |
개발자관리자
|
19년 전 | 1585 | |
| 510 |
개발자관리자
|
19년 전 | 1740 | |
| 509 |
개발자관리자
|
19년 전 | 1840 | |
| 508 |
개발자관리자
|
19년 전 | 2006 | |
| 507 |
개발자관리자
|
19년 전 | 1685 | |
| 506 |
개발자관리자
|
19년 전 | 1808 | |
| 505 |
개발자관리자
|
19년 전 | 1773 | |
| 504 |
개발자관리자
|
19년 전 | 1853 | |
| 503 |
개발자관리자
|
19년 전 | 1521 | |
| 502 |
개발자관리자
|
19년 전 | 2648 | |
| 501 | 19년 전 | 1997 | ||
| 500 | 19년 전 | 3236 | ||
| 499 | 19년 전 | 3266 | ||
| 498 | 19년 전 | 2524 | ||
| 497 | 19년 전 | 2601 | ||
| 496 | 19년 전 | 2440 | ||
| 495 | 19년 전 | 2699 | ||
| 494 | 19년 전 | 2678 | ||
| 493 | 19년 전 | 3179 | ||
| 492 | 19년 전 | 2889 | ||
| 491 | 19년 전 | 5307 | ||
| 490 |
|
19년 전 | 2124 | |
| 489 |
|
19년 전 | 2212 | |
| 488 |
|
19년 전 | 2007 | |
| 487 |
|
19년 전 | 1944 | |
| 486 |
|
19년 전 | 1940 | |
| 485 |
|
19년 전 | 2137 | |
| 484 |
|
19년 전 | 3212 | |
| 483 |
|
19년 전 | 3091 | |
| 482 |
|
19년 전 | 2853 | |
| 481 |
|
19년 전 | 2546 | |
| 480 |
|
19년 전 | 2631 | |
| 479 |
|
19년 전 | 2295 | |
| 478 |
|
19년 전 | 2328 | |
| 477 |
개발자관리자
|
19년 전 | 1590 | |
| 476 |
개발자관리자
|
19년 전 | 2309 | |
| 475 |
개발자관리자
|
19년 전 | 2659 | |
| 474 |
개발자관리자
|
19년 전 | 2656 | |
| 473 |
개발자관리자
|
19년 전 | 2968 | |
| 472 | 19년 전 | 2735 | ||
| 471 | 19년 전 | 1726 | ||
| 470 | 19년 전 | 1826 | ||
| 469 |
|
19년 전 | 2726 | |
| 468 |
|
19년 전 | 2221 | |
| 467 |
|
19년 전 | 3995 | |
| 466 |
|
19년 전 | 2508 | |
| 465 | 19년 전 | 2378 | ||
| 464 | 19년 전 | 3522 | ||
| 463 |
|
19년 전 | 3100 | |
| 462 |
|
19년 전 | 2242 | |
| 461 |
|
19년 전 | 3035 | |
| 460 |
|
19년 전 | 2240 | |
| 459 |
|
19년 전 | 3101 | |
| 458 |
|
19년 전 | 3527 | |
| 457 |
|
19년 전 | 5212 | |
| 456 |
|
19년 전 | 3133 | |
| 455 |
스마일미디어
|
19년 전 | 3132 | |
| 454 |
스마일미디어
|
19년 전 | 2719 | |
| 453 |
스마일미디어
|
19년 전 | 2462 | |
| 452 |
스마일미디어
|
19년 전 | 2719 | |
| 451 |
스마일미디어
|
19년 전 | 2447 | |
| 450 |
스마일미디어
|
19년 전 | 2563 | |
| 449 |
스마일미디어
|
19년 전 | 2364 | |
| 448 |
스마일미디어
|
19년 전 | 2692 | |
| 447 | 19년 전 | 2959 | ||
| 446 |
스마일미디어
|
19년 전 | 3244 | |
| 445 |
스마일미디어
|
19년 전 | 7048 | |
| 444 |
스마일미디어
|
19년 전 | 5168 | |
| 443 |
스마일미디어
|
19년 전 | 2426 | |
| 442 |
스마일미디어
|
19년 전 | 5162 | |
| 441 |
스마일미디어
|
19년 전 | 3100 | |
| 440 |
|
19년 전 | 2460 | |
| 439 | 19년 전 | 2155 | ||
| 438 | 19년 전 | 3566 | ||
| 437 |
|
19년 전 | 2869 | |
| 436 |
|
19년 전 | 3248 | |
| 435 |
|
19년 전 | 2888 | |
| 434 | 19년 전 | 3382 | ||
| 433 |
sjsjin
|
19년 전 | 2711 | |
| 432 |
sjsjin
|
19년 전 | 3453 | |
| 431 |
sjsjin
|
19년 전 | 2416 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기