메뉴 건너뛰기

XE : Xpress Engine


XE에 대한 생각! XE에 대한 공감! - XE를 사용하는 다른 사람들과 의견을 나눌 수 있는 곳입니다. 많은 의견 공유로 더 좋은 XE를 만들어 주세요.


XE 사용팁

XE의 경우에는 모든 출력을 차근 차근 만들어 모아놓은 다음, 모든 작업을 수행하고 마지막에 한꺼번에 출력하기 때문에, 중간에 사용자가 디버깅 등을 위해 출력을 하게 될 경우 예외 없이 에러 메시지를 만나게 됩니다.

encoding_error.png

위 그림처럼 브라우저에서 오류를 보여주거나, 헤더 출력 오류 메시지가 나오게 될 것입니다.

그렇다면 어떻게 디버깅을 하란 말인가? 답은 그리 어렵지 않습니다. 이미 XE에서는 훌륭한 디버깅 방법을 마련해두고 있습니다.


config/config.inc.php 파일을 보면 이에 대한 해답을 찾을 수 있습니다. 이 글에서는 현재 배포 버전인 XE 1.2.0 버전을 기준으로 이야기합니다.

config/config.inc.php
    /**
     * @brief 기본 설정에 우선하는 사용자 설정 파일
     * config/config.user.inc.php 파일에 아래 내용을 저장하면 됨
     * <?php 
     * define('__DEBUG__', 0);
     * define('__DEBUG_OUTPUT__', 0);
     * define('__DEBUG_PROTECT__', 1);
     * define('__DEBUG_PROTECT_IP__', '127.0.0.1');
     * define('__DEBUG_DB_OUTPUT__', 0);
     * define('__LOG_SLOW_QUERY__', 0);
     * define('__OB_GZHANDLER_ENABLE__', 1);
     * ?>
     */
    if(file_exists(_XE_PATH_.'config/config.user.inc.php')) {
        require _XE_PATH_.'config/config.user.inc.php';
    }

위에서 보면 알겠지만, 사용자 설정 파일을 작성해 놓으면 이 설정을 기본 설정보다 우선해서 적용시키기 때문에 사용자 입맛에 맞게 디버깅을 할 수 있습니다.

이를 위해 우선 config/config.user.inc.php 파일을 만들도록 합니다. 이 파일 이름은 config/config.inc.php 파일에서 기본으로 찾는 파일 이름이기 때문에 특별한 이유가 없다면 그대로 사용하는 것이 좋습니다.


이 파일의 내용은 config/config.inc.php 파일의 본문 내용에 나와있는 것처럼 자신의 설정에 맞도록 적어주면 됩니다.

config/config.user.inc.php
<?php

define('__DEBUG__', 1);
define('__DEBUG_OUTPUT__', 2);
define('__DEBUG_PROTECT__', 1);
define('__DEBUG_PROTECT_IP__', '123.123.123.123');
define('__DEBUG_DB_OUTPUT__', 0);
define('__LOG_SLOW_QUERY__', 0);
define('__OB_GZHANDLER_ENABLE__', 1);

?>


config/config.inc.php 파일을 보면 이미 나와있지만, 위 설정값을 하나씩 살펴보자면

__DEBUG__
기본값은 0 으로, 이것은 디버깅 메시지 출력을 할 것인지, 어떤 것을 할 것인지를 설정하는 지시자입니다.
  • 0 : 디버그 메시지를 생성/ 출력하지 않음
  • 1 : debugPrint() 함수를 통한 메시지 출력
  • 2 : 소요시간, Request/Response info 출력
  • 4 : DB 쿼리 내역 출력
이 지시자의 설정값은 비트 OR 연산으로 값을 설정합니다. 예를 들어, 모든 설정을 활성시키고자 한다면 7로 설정하면 됩니다.

__DEBUG_OUTPUT__
기본값은 0 으로, 이것은 디버그 메시지의 출력 방법에 대해 설정하는 지시자입니다.
  • 0 : files/_debug_message.php 에 연결하여 출력
  • 1 : HTML 최하단에 주석으로 출력 (Response Method가 HTML 일 때)
  • 2 : Firebug 콘솔에 출력 (PHP >= 5.2.0. Firebug/FirePHP 플러그인 필요)
여기에서 아주 유용한 것이 Mozilla FirefoxFirebugFirePHP 애드온을 이용하는 방법인데, Firefox를 사용한다면 이 두 애드온을 설치해서 이 방법을 이용하는 것이 여러 모로 편리할 것입니다.

__DEBUG_OUTPUT__ 의 값을 2 혹은 다른 적절한 값으로 설정하고, Firebug와 FirePHP 애드온을 설치한 후 활성시키면, XE 디버깅을 위한 준비는 끝나게 됩니다.

firephp_enabled.png

__DEBUG_PROTECT__
기본값은 1 이고, 이것은 __DEBUG_OUTPUT__ 지시자의 설정값을 1 혹은 2로 했을 때, 즉 디버그 메시지를 HTML의 주석으로 보거나 FirePHP 콘솔를 통해 볼 수 있도록 설정했을 때 특정 IP 주소에서 접속했을 때만 보여줄 것인가를 설정하는 것입니다.
  • 0 : 제한 없음 (권장하지 않음)
  • 1 : 지정한 IP 주소에만 허용
가급적 1 로 설정하는 것이 좋을 것입니다. 그렇지 않은 경우 이로 인해 발생할 수도 있는 문제는 심각해질 수도 있습니다.

__DEBUG_PROTECT_IP__
기본값은 127.0.0.1 이고, 이 지시자는 __DEBUG_PROTECT__ 지시자의 값을 1로 설정했을 때 디버그 메시지 출력을 허용할 IP 주소를 설정하는 것입니다. 여기에는 자신의 IP 주소를 설정해주면 됩니다.


이제 모든 준비가 끝났습니다. 설정이 제대로 되었다면 아래 그림과 같이 디버그 메시지가 나올 것입니다. 이제 Firebug와 FirePHP 애드온를 통해 브라우저 상에서 손쉽게 디버그 메시지를 확인할 수 있습니다.

firephp_message2.png

당연한 이야기이지만, 디버그 메시지 출력을 위해서는, 디버그하기 원하는 곳에서 debugPrint() 함수를 호출해줘야 합니다.

addons/add_content.addon.php
    require_once($addon_path .'add_content.lib.php');

    $output = preg_replace_callback($pos_regx, getAddContent, $output);
    debugPrint("Hi, there!!");
    debugPrint("called_position = $called_position");


참~ 쉽지요!



덧. 이 글은 제 블로그에 올린 글을 수정한 것이라 어투가 약간 이상할 수도 있습니다. 수정한다고는 했는데, 어색하더라도 양해해주시면 감사하겠습니다. 혹시 잘못된 점이 있다면 지적해주시면 수정하도록 하겠습니다.


번호 제목 글쓴이 날짜 조회 수
공지 질문은 묻고 답하기로~ TSCMD 2012.02.03 366
494 묻고 답하기용 게시판 [1] [레벨:1]yunesb 2009.01.24 975
493 음악판매 [5] [레벨:1]물푸레646 2008.12.27 3421
492 서브 메뉴 배경색 바꾸기 [4] file [레벨:4]Chang-Jo(창조) 2007.08.17 7315
491 BGM 가로스크롤바 없애는 방법.. [레벨:2]청개굴이 2009.06.03 1063
490 글쓴이 이메일 정보 감추기 [2] [레벨:12]대암지기 2007.11.22 1045
» Firebug와 FirePHP를 통한 XpressEngine의 디버깅 [3] file CMmooo 2009.04.01 1233
488 BGM 쓰시는분 게시판 에서 첨부파일 다운받을때 끊어지시죠?ㅎㅎ [4] [레벨:11]우리아기 2009.05.23 972
487 스프링노트 연동문제 [2] [레벨:1]nonoboy 2009.05.21 980
486 별도 페이지 로그인방법 [레벨:2]cornet 2009.05.21 1196
485 까페 아이디 삭제후 동일 아이디로 생성하는 방법 [레벨:3]키스메리 2009.05.15 3550
484 winxp IE7 rwapm에서 한글이름파일 업로드 [12] [레벨:2]공수래 2007.09.17 18455
483 페이지 및 게시판 메뉴 경로 [2] file [레벨:1]자반튀김 2009.04.15 4523
482 이전글, 다음글 얻기 [24] [레벨:18]라르게덴 2008.05.29 6110
481 위지윅 에디터의 관리의 활성 비활성이 안될 경우 해결책 [레벨:6]김유중345 2009.05.01 4272
480 1.2.2 업데이트 이후 위젯이 출력안되시는 분들 [1] [1] [레벨:5]반도체맨 2009.05.01 995
479 BNU님의 Planner XE 1.2 버젼(일정관리) [10] file [레벨:6]개돌 2009.04.21 4747
478 [질문]회원가입시 음력생일입력 가능 한가요? [1] [레벨:1]신정 2009.04.27 3657
477 주민등록번호 입력 폼 추가 (1.1.5 기준) [39] [레벨:6]개돌 2009.02.16 5309
476 XE 위키에 최근 접속 페이지 정보 출력 file [레벨:6]개돌 2009.04.27 4067
475 초보 xe1.1.5에대한질문 [3] [레벨:3]울프 2009.04.26 3388