웹마스터 팁

XE가 1.2.0 버전으로 올라오면서 게시물의 확장 변수 값에 대한 DB 저장 방식이 바뀌었습니다.
그래서, 1.1.6 이하 버전에서 1.2.0 이상 버전으로 업그레이드할 때 게시물의 확장 변수값들을 새로운 DB 형태로 저장하게 되는데, 이 과정에서 일부 값만 이동되고 나머지 값들은 소실되는 문제점이 있습니다.

현재 이 문제는 수정한 상태입니다만, 다음 배포본에나 추가될 예정입니다.
따라서, 다음 배포본이 나오기 이전에 1.1.6 이하 버전에서 업그레이드를 하실 분들은 아래 패치를 적용하신 후에 업그레이드를 하시기 바랍니다.

수정해줘야할 파일은 modules/module/module.class.php 파일입니다.

1.2.1 버전을 기준으로 위 파일에서 183번째 줄에

                        // 게시글 확장변수 키 등록
                        if(count($document_extra_keys)) {
                            foreach($document_extra_keys as $var_idx => $val) {
                                $oDocumentController->insertDocumentExtraKey($module_srl, $var_idx, $val->name, $val->type, $val->is_required, $val->search, $val->default, $val->desc, 'extra_vars'.$var_idx);
                            }

                            // 확장변수가 존재하면 확장변수 가져오기
                            $doc_args = null;
                            $doc_args->module_srl = $module_srl;
                            $doc_args->list_count = 100;
                            $doc_args->sort_index = 'list_order';
                            $doc_args->order_type = 'asc';
                            $doc_args->page = 1;
                            $output = executeQueryArray('document.getDocumentList', $doc_args);
                            if($output->toBool() && $output->data && count($output->data)) {
                                foreach($output->data as $document) {
                                    if(!$document) continue;
                                    foreach($document as $key => $var) {
                                        if(strpos($key,'extra_vars')!==0 || !trim($var) || $var== 'N;') continue;
                                        $var_idx = str_replace('extra_vars','',$key);
                                        $oDocumentController->insertDocumentExtraVar($module_srl, $document->document_srl, $var_idx, $var, 'extra_vars'.$var_idx, $lang_code);
                                    }
                                }
                                $doc_args->page++;
                            }
                        }

와 같은 내용이 있습니다. 이 부분을 아래와 같이 수정합니다.

                        // 게시글 확장변수 키 등록
                        if(count($document_extra_keys)) {
                            foreach($document_extra_keys as $var_idx => $val) {
                                $oDocumentController->insertDocumentExtraKey($module_srl, $var_idx, $val->name, $val->type, $val->is_required, $val->search, $val->default, $val->desc, 'extra_vars'.$var_idx);
                            }

                            $oDocumentModel = &getModel('document');
                            $total_count = $oDocumentModel->getDocumentCount($module_srl);

                            if ($total_count > 0) {
                                $per_page = 100;
                                $total_pages = (int) (($total_count - 1) / $per_page) + 1;

                                // 확장변수가 존재하면 확장변수 가져오기
                                $doc_args = null;
                                $doc_args->module_srl = $module_srl;
                                $doc_args->list_count = $per_page;
                                $doc_args->sort_index = 'list_order';
                                $doc_args->order_type = 'asc';

                                for ($doc_args->page = 1; $doc_args->page <= $total_pages; $doc_args->page++) {
                                    $output = executeQueryArray('document.getDocumentList', $doc_args);

                                    if ($output->toBool() && $output->data && count($output->data)) {
                                        foreach ($output->data as $document) {
                                            if (!$document) continue;
                                            foreach ($document as $key => $var) {
                                                if (strpos($key, 'extra_vars') !== 0 || !trim($var) || $var == 'N;') continue;
                                                $var_idx = str_replace('extra_vars','',$key);
                                                $oDocumentController->insertDocumentExtraVar($module_srl, $document->document_srl, $var_idx, $var, 'extra_vars'.$var_idx, $lang_code);
                                            }
                                        }
                                    }
                                } // for total_pages
                            } // if count
                        }


수정된 modules/module/module.class.php 파일을 첨부합니다.

우선 1.2.1 버전으로 파일들을 업그레이드한 후에 관리자 페이지에서 모듈 설치/업그레이드를 하기 이전에 이 파일을 modules/module/module.class.php 로 덮어쓰시기 바랍니다.

패치하기 이전에 관리자 페이지에서 모듈 설치/업그레이드를 한 경우에는 소실된 정보를 복구할 수 없습니다.

업그레이드하기 이전에는 항상 DB와 files 디렉토리를 백업하는 습관을 가지면, 업그레이드를 진행하면서 문제가 발생했을 때 복구할 수 있는 확률이 높아집니다. 물론 이런 일이 없도록 해야함이 최선이겠지만요.


제목 글쓴이 날짜
빠른 글 쓰기 - 메인 페이지에서 글 쓰기 [1] file 윈컴이 2013.09.23
[주옥시리즈]댓글창에 배경 이미지 넣기 [3] file socialskyo 2013.09.22
스케치북 게시판에 로그인/로그아웃 버튼 만들기 [1] Arp. 2013.09.22
템플릿 compile 오류가 날 때 Lansi 2013.09.22
[주옥시리즈] 에디터 컴포넌트, 이모티콘등 앞으로 빼기 [4] socialskyo 2013.09.21
에디터 비활성화 오류시 점검해야 할것. [1] file 도라미 2013.09.20
Apache .htaccess 작성요령 [10] 컴매냐 2013.09.19
웹사이트 최적화 방법론 [4] 다크진 2013.09.17
모바일에서 스케치북 게시판 댓글 펼침이 안 될 때.... file 손자 2013.09.17
영문 스팸 방지 [13] 스토리웨이 2013.09.16
스케치북 게시판 목록 홀수 줄 에만 배경지정 [3] socialskyo 2013.09.14
XP + IE8 에서 갑자기 페이지 오류메시지가 뜰 경우 [1] file 다크진 2013.09.14
에디터 비활성화 문제 해결했습니다! [2] 엘로이스 2013.09.13
게시글 추천 아이피 가져오기 file Stellar 2013.09.12
추천 취소 기능 만들기 [5] file Summer 2013.09.11
[주옥시리즈] 배너 클릭시 포인트지급 모듈, Portal XE [1] socialskyo 2013.09.09
[주옥시리즈] [1.7.4] 로그인창 옆에 신규 쪽지 수 보여주기 [3] socialskyo 2013.09.09
[주옥시리즈]댓글 작성, 추천후 다운로드 받을수 있게 하기. socialskyo 2013.09.09
[주옥시리즈]글 목록을 조회수 별로 색상 지정하기 socialskyo 2013.09.09
[주옥시리즈]댓글 작성, 추천후 다운로드 받을수 있게 하기. socialskyo 2013.09.09