크게 작게 인쇄

[그누보드][CKEditor] 그누보드에 적용하기

1. 먼저 ckeditor(위지윅 에디터)를 다운 받습니다.
    ckeditor - http://ckeditor.com/download
다운받은 ckeditor를 압축 푼뒤  그누보드 / ckeditor 폴더에 업로드 합니다.

 
2-1. 그누보드 / skin / board / basic / write.skin.php  4줄
[ 원본 ]
if ($is_dhtml_editor) {
    include_once("$g4[path]/lib/cheditor4.lib.php");
    echo "<script src='$g4[cheditor4_path]/cheditor.js'></script>";
    echo cheditor1('wr_content', '100%', '250');
}

[수정 ]
if ($is_dhtml_editor) {
    //include_once("$g4[path]/lib/ckeditor.lib.php");
    echo "<script src='$g4[path]/ckeditor/ckeditor.js'></script>";
    //echo ckeditor1('wr_content', '100%', '250');
}


2-2. 그누보드 / skin / board / basic / write.skin.php 130라인
[ 원본 ]
        <? if ($is_dhtml_editor) { ?>
            <?=cheditor2('wr_content', $content);?>

[ 수정 ]
        <?php if ($is_dhtml_editor) { ?>
            <?php //echo ckeditor2('wr_content', $content); ?>
            <textarea id="wr_content" name="wr_content" class="tx" required style='width:100%; word-break:break-all;' rows="10" title="내용"><?php echo $content; ?> </textarea>
            <script type="text/javascript">
                CKEDITOR.replace('wr_content',
                {
                skin: 'v2', //에디터 스킨 (kama, office2003, v2) 
                customConfig : '<?php echo $g4[path]; ?>/ckeditor/config.js', //커스텀설정js파일위치
                filebrowserUploadUrl: '<?php echo $g4[path]; ?>/ckeditor/upload.php?type=Files',
                filebrowserImageUploadUrl: '<?php echo $g4[path]; ?>/ckeditor/upload.php?type=Images',
                filebrowserFlashUploadUrl: '<?php echo $g4[path]; ?>/ckeditor/upload.php?type=Flash'
                }
            );
            </script>


2-3. 그누보드 / skin / board / basic / write.skin.php  339라인
[ 원본 ]
    if ($is_dhtml_editor) echo cheditor3('wr_content');

[ 수정 ]
    //if ($is_dhtml_editor) echo cheditor3('wr_content');


3. ckeditor 환경설정 변경
그누보드 / ckeditor / config.js 파일을 아래 내용으로 교체합니다.

/*
Copyright (c) 2003-2011, CKSource - Frederico Knabben. All rights reserved.
For licensing, see LICENSE.html or http://ckeditor.com/license
*/
 
CKEDITOR.editorConfig = function( config )
{
// Define changes to default configuration here. For example:
// config.language = 'fr';
// config.uiColor = '#AADC6E';
 
  config.docType = '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">';
  config.font_defaultLabel = '굴림';
  config.font_names = '굴림/Gulim;돋움/Dotum;바탕/Batang;궁서/Gungsuh;Arial/Arial;Comic Sans MS/Comic Sans MS;Courier New/Courier New;Georgia/Georgia;Lucida Sans Unicode/Lucida Sans Unicode;Tahoma/Tahoma;Times New Roman/Times New Roman;Trebuchet MS/Trebuchet MS;Verdana/Verdana';
  config.fontSize_defaultLabel = '12px';
  config.fontSize_sizes = '8/8px;9/9px;10/10px;11/11px;12/12px;14/14px;16/16px;18/18px;20/20px;22/22px;24/24px;26/26px;28/28px;36/36px;48/48px;';
  config.language = "ko";
  config.resize_enabled = true;
  config.enterMode = CKEDITOR.ENTER_BR;
  config.shiftEnterMode = CKEDITOR.ENTER_P;
  config.startupFocus = true;
  config.uiColor = '#eaebe7';
  config.toolbarCanCollapse = false;
  config.menu_subMenuDelay = 0;
  config.width ='100%';
  config.height ='200';
  config.toolbar = [['Bold','Italic','Underline','Strike','-','Subscript','Superscript','-','TextColor','BGColor','-','JustifyLeft','JustifyCenter','JustifyRight','JustifyBlock','-','Link','Unlink','-','Find','Replace','SelectAll','RemoveFormat','-','Image','Flash','Table','Smiley','SpecialChar'],'/',['Source','Preview','-','ShowBlocks','-','Font','FontSize','Cut','Copy','Paste','PasteText','PasteFromWord','Undo','Redo','-','Maximize','About']];
};


4. ckeditor 에서 업로드 가능하도록  upload.php 파일을 추가합니다.


4-1. 그누보드 / data / ckeditor / image  폴더를 생성합니다.
ckeditor 와 ckeditor / image 폴더의 퍼미션을 777 로 변경합니다.


4-2. 그누보드 / ckeditor / upload.php 파일을 생성후 아래 내용을 삽입합니다.

※ 중복파일 체크 및 파일 이름이 한글이거나 공백이 포함 된 경우 오류발생하는 미완성 입니다. ※

<?php
include_once("_common.php");
$up_url = '/gnuboard/data/ckeditor/image'; // 기본 업로드 URL
$up_dir = '../data/ckeditor/image'; // 기본 업로드 폴더
 
// 업로드 DIALOG 에서 전송된 값
$funcNum = $_GET['CKEditorFuncNum'] ;
$CKEditor = $_GET['CKEditor'] ;
$langCode = $_GET['langCode'] ;
 
if(isset($_FILES['upload']['tmp_name']))
{
    $file_name = $_FILES['upload']['name'];
    $ext = strtolower(substr($file_name, (strrpos($file_name, '.') + 1)));
 
    if ('jpg' != $ext && 'jpeg' != $ext && 'gif' != $ext && 'png' != $ext && 'swf' != $ext)
    {
        echo '허용되지 않은 확장자입니다.';
        return false;
    }
 
    $save_dir = sprintf('%s/%s', $up_dir, $file_name);
    $save_url = sprintf('%s/%s', $up_url, $file_name);
 
    if (move_uploaded_file($_FILES["upload"]["tmp_name"],$save_dir))
        echo "<script>window.parent.CKEDITOR.tools.callFunction($funcNum, '$save_url', '업로드완료');</script>";
}
?>


5. 그누보드 / bbs / write_update.php  7~8줄을 주석처리합니다.
[ 원본 ]
if (substr_count($wr_content, "&#") > 50) {
    alert("내용에 올바르지 않은 코드가 다수 포함되어 있습니다.");
    exit;
}

[ 수정 ]
if (substr_count($wr_content, "&#") > 50) {
    //alert("내용에 올바르지 않은 코드가 다수 포함되어 있습니다.");
    //exit;
}


참고자료
http://www.autoboy.pe.kr/130
http://happyjung.com/gnuboard/bbs/board.php?bo_table=lecture&wr_id=1109




※ 로그인 하시면 원본파일을 볼 수 있습니다. ※

0
코멘트 0
그누보드팁 | 전체게시물 160
안내

포인트안내닫기

  • 글읽기0
  • 글쓰기100
  • 댓글쓰기50
  • 다운로드-500
그누보드팁리스트
번호 제목 글쓴이 날짜 조회 추천
100 텍스트
[그누보드][CKEditor] 그누보드에 적용하기
슈퍼맨 웹스터디 04-25 7351 0
99 텍스트 슈퍼맨 웹스터디 04-25 5030 0
98 텍스트 슈퍼맨 웹스터디 04-14 4910 0
97 파일첨부 슈퍼맨 웹스터디 03-30 4786 0
96 텍스트 슈퍼맨 웹스터디 03-19 4691 0
95 텍스트 슈퍼맨 웹스터디 03-17 4376 0
94 텍스트 슈퍼맨 웹스터디 03-15 4861 0
93 텍스트 +1 슈퍼맨 웹스터디 03-15 4705 1
92 텍스트 슈퍼맨 웹스터디 03-14 5783 0
91 텍스트 슈퍼맨 웹스터디 03-13 4456 0
90 텍스트 +1 슈퍼맨 웹스터디 02-24 4530 0
89 텍스트 슈퍼맨 웹스터디 02-24 5046 0
88 텍스트 슈퍼맨 웹스터디 02-22 5454 0
87 텍스트 링크 슈퍼맨 웹스터디 02-22 5002 0
86 텍스트 슈퍼맨 웹스터디 02-22 6685 0
85 파일첨부 슈퍼맨 웹스터디 02-22 4792 0
84 텍스트 슈퍼맨 웹스터디 02-22 5242 0
83 텍스트 슈퍼맨 웹스터디 02-14 5189 0
82 텍스트 슈퍼맨 웹스터디 02-14 5278 0
81 파일첨부 +3 슈퍼맨 웹스터디 02-13 5084 0