코멘트 비밀글 오류 도와주세요ㅠㅠ! > 그누4 질문답변

그누4 질문답변

그누보드4 관련 질문은 QA 로 이전됩니다. QA 그누보드4 바로가기
기존 게시물은 열람만 가능합니다.

코멘트 비밀글 오류 도와주세요ㅠㅠ! 정보

코멘트 비밀글 오류 도와주세요ㅠㅠ!

본문

오류가 나는곳의 주소를 알려주시면 더 빠르고 정확하게 답변 받을 수 있습니다.

오류 주소 :


안녕하세요. 2012년 마무리 잘들 하고 계신가요?
다름이 아니라...
지금쓰고 있는 게시판 스킨에서 댓글 코멘트에 오류가 있네요ㅠㅠ

A(글작성자)가 글을 쓰고, B(댓글작성자)가 댓글을 쓰고, C(댓글에 리댓글로 비밀글을 쓴 사람)가 B의 댓글에 비밀글로 코멘트를 달면...

A에게 그 내용이 보이고 B에게는 보이지 않습니다ㅠㅠ
원래는 A는 볼 수 없고 B와 C만 볼 수 있잖아요..ㅠㅠ


그러니까 댓글에 비밀글로 코멘트를 달면 글 작성자는 볼 수 없고
비밀댓글이 달린 댓글의 작성자와 비밀댓글을 쓴 당사자만 볼 수 있어야 하는데 말이죠 ㅠㅠ

관리자설정에서 비밀글 사용 설정했구요,
댓글 자체의 비밀글은 잘 적용 됩니다. 다만.. 리댓글의 비밀글이 이상하다는 거죠ㅠㅠ


아래는 해당 스킨의 코멘트 스킨입니다. 어떻게 고쳐야 올바르게 제 기능을 할까요?

도와주시면 정말 감사하겠습니다. 확인 후 바로 채택 해드릴게요ㅠㅠ

(익명 스킨으로 수정해서.. 이름부분은 전부 익명으로 표기됩니다.)


<?
if (!defined("_GNUBOARD_")) exit; // 개별 페이지 접근 불가
?>

<script type="text/javascript">
// 글자수 제한
var char_min = parseInt(<?=$comment_min?>); // 최소
var char_max = parseInt(<?=$comment_max?>); // 최대
</script>

<style type="text/css">
<!--
td,textarea,input {
font-family: "돋움", Arial, Verdana, Helvetica, geneva, sans-serif;
font-size:9pt;
color:#222222;
line-height: 180%;}

a:link { text-decoration: none ; color: #222222; }
a:visited { text-decoration: none ; color: #222222; }
a:active { text-decoration: none ; color: #222222; }
a:hover { text-decoration: underline; color:#538AE6; }

.board_top { height: 30px;}
.board_comment { width:100%; table-layout:fixed;}

.board_comment_write { width:100%;}
.board_comment_write td { background-color: #F3F3F3;}
.board_comment_write .wtd0 { height: 2px; background-color: #DEDEDE;}
.board_comment_write .wtd1 { padding: 5px;}
.board_comment_write .wtd2 { padding-left: 5px; padding-top: 5px; text-align: left; width: 130px; height: 50px; }
.board_comment_write .wtd3 { text-align: left; height: 50px; }
.board_comment_write .wtd4 { padding-right: 5px; text-align: right; }

.board_comment_list  { width:100%;}
.board_comment_list td {}
.board_comment_list .ltd1 { height: 1px; background-color: #DDD;}
.board_comment_list .ltd2 { height: 5px;}
.board_comment_list .ltd3 { text-align: left; width: 80px; padding-left: 5px; padding-top: 5px; vertical-align: top; }
.board_comment_list .ltd4 { width: 2px; background-color: #EEE;}
.board_comment_list .ltd5 { text-align: left; padding-left: 10px;}
.board_comment_list .ltd6 { text-align: right; padding-left: 5px;}
.board_comment_list .ltd7 { text-align: left;  padding-top: 10px; padding-left: 10px; line-height: 150%;}


.board_comment_list td .datetime { font:normal 10px tahoma; color:#BABABA; text-align:right; }
.board_comment_list td .ip { font:normal 10px tahoma; color:#BABABA; text-align:right; }

.margin_div { height: 10px;}
.input {border:1px solid #D9D9D9;}
.textbox {border: 1px solid #CCC;}

-->
</style>

<? if ($cwin==1) { ?>
<table width=100% cellpadding="10" align="center" class="board_comment"><tr><td>
<? } ?>

<!-- 코멘트 리스트 -->
<div id="commentContents">
<?
for ($i=0; $i<count($list); $i++) {
    $comment_id = $list[$i][wr_id];
?>
<a name="c_<?=$comment_id?>"></a>
  <table width="100%" cellpadding="0" cellspacing="0" border="0">
  <tr>
    <td><? for ($k=0; $k<strlen($list[$i][wr_comment_reply]); $k++) echo "&nbsp;&nbsp;"; ?></td>
      <td>
        <table border="0" cellpadding="0" cellspacing="0" class="board_comment_list">
          <tr>
    <td colspan="4" class="ltd1"></td>                   
  </tr>
                <tr>
    <td colspan="4" class="ltd2"></td>                   
  </tr>
         
        <tr>
                  <td rowspan="2" class="ltd3"><strong><? echo "익명"; ?></strong></td>
                      <td rowspan="2" class="ltd4"></td>           
                      <td class="ltd5"><span class="datetime">(<?=date("y-m-d H:i",strtotime($list[$i][datetime]))?>)</span></td>
                  <td class="ltd6">&nbsp;
<? if ($list[$i][is_reply]) { echo "<a href=\"javascript:comment_box('{$comment_id}', 'c');\"><img src='$board_skin_path/img/co_btn_reply.gif' border=0 align=absmiddle alt='댓글답변'></a> "; } ?>
                <? if ($list[$i][is_edit]) { echo "<a href=\"javascript:comment_box('{$comment_id}', 'cu');\"><img src='$board_skin_path/img/co_btn_modify.gif' border=0 align=absmiddle alt='댓글수정'></a> "; } ?>
                <? if ($list[$i][is_del])  { echo "<a href=\"javascript:comment_delete('{$list[$i][del_link]}');\"><img src='$board_skin_path/img/co_btn_delete.gif' border=0 align=absmiddle alt='댓글삭제'></a> "; } ?>
                </td>
              </tr>
                             
               
                <!-- 코멘트 출력 -->
              <tr>
            <td colspan="2" class="ltd7">
             
             
                <?
                if (strstr($list[$i][wr_option], "secret")) echo "<span style='color:#ff6600;'>*</span> ";
                  $str = $list[$i][content];
                if (strstr($list[$i][wr_option], "secret"))
                    $str = "<span class='small' style='color:#ff6600;'>$str</span>";

                $str = preg_replace("/\[\<a\s.*href\=\"(http|https|ftp|mms)\:\/\/([^[:space:]]+)\.(mp3|wma|wmv|asf|asx|mpg|mpeg)\".*\<\/a\>\]/i", "<script>doc_write(obj_movie('$1://$2.$3'));</script>", $str);
                $str = preg_replace("/\[\<a\s.*href\=\"(http|https|ftp)\:\/\/([^[:space:]]+)\.(swf)\".*\<\/a\>\]/i", "<script>doc_write(flash_movie('$1://$2.$3'));</script>", $str);
                $str = preg_replace("/\[\<a\s*href\=\"(http|https|ftp)\:\/\/([^[:space:]]+)\.(gif|png|jpg|jpeg|bmp)\"\s*[^\>]*\>[^\s]*\<\/a\>\]/i", "<img src='$1://$2.$3' id='target_resize_image[]' onclick='image_window(this);' border='0'>", $str);
                echo $str;
                ?>
               
                <span id='edit_<?=$comment_id?>' style='display:none;'></span><!-- 수정 -->
                <span id='reply_<?=$comment_id?>' style='display:none;'></span><!-- 답변 -->
                <input type=hidden id='secret_comment_<?=$comment_id?>' value="<?=strstr($list[$i][wr_option],"secret")?>">
                <textarea id='save_comment_<?=$comment_id?>' style='display:none;'><?=get_text($list[$i][content1], 0)?></textarea>
                </td>
                </tr>
            <tr>
                  <td class="ltd2"></td>                 
                </tr>
            </table>
        </td>
      </tr>
  </table>
   
<? } ?>
</div>
<!-- 코멘트 리스트 -->

<? if ($is_comment_write) { ?>
<!-- 코멘트 입력 -->
<div id=comment_write style="display:none;">
<table width="100%" border="0" cellpadding="0" cellspacing="0" ><tr><td>
  <form name="fviewcomment" method="post" action="./write_comment_update.php" onsubmit="return fviewcomment_submit(this);" style="margin:0px;">
<input type=hidden name=w          id=w value='c'>
<input type=hidden name=bo_table    value='<?=$bo_table?>'>
<input type=hidden name=wr_id      value='<?=$wr_id?>'>
<input type=hidden name=comment_id  id='comment_id' value=''>
<input type=hidden name=sca        value='<?=$sca?>' >
<input type=hidden name=sfl        value='<?=$sfl?>' >
<input type=hidden name=stx        value='<?=$stx?>'>
<input type=hidden name=spt        value='<?=$spt?>'>
<input type=hidden name=page        value='<?=$page?>'>
<input type=hidden name=cwin        value='<?=$cwin?>'>
<input type=hidden name=is_good    value=''>
            <div class="margin_div"></div>
<table cellpadding="0"  cellspacing="0" class="board_comment_write">
                <tr><td colspan="6" class="wtd0"></td></tr>
                <tr>
        <? if ($is_guest) { ?>
        <td class="wtd2"><img id='kcaptcha_image' border='0' width=120 height=45 onclick="imageClick();" style="cursor:pointer;" title="글자가 잘 보이지 않는 경우 그림을 클릭하시면 새로운 글자가 나옵니다."></td>
    <td class="wtd3"><input title="왼쪽의 글자를 입력하세요." name="wr_key" size="8"  class="input"></td>     
  <? } ?>
             
        <? if ($is_guest) { ?>           
        <td class="wtd3">이름&nbsp;<input type="text" maxLength="20" size="8" name="wr_name"  class="input"></td>
  <td class="wtd3">비밀번호&nbsp;<input type="password" maxLength="20" size="8" name="wr_password" class="input"></td>
        <? }?>
       
        <td class="wtd3">비밀글<input type=checkbox id="wr_secret" name="wr_secret" value="secret"><? if ($comment_min || $comment_max) { ?>  <span id=char_count></span>글자 <? }?></td>
        <td class="wtd4"><input type="image" src="<?=$board_skin_path?>/img/co_btn_write.gif" border="0" accesskey='s' alt="댓글작성완료"></td>         
</tr>           
              <tr>
  <td colspan="6" class="wtd1">
        <textarea id="wr_content" name="wr_content" rows="5" cols="1" 
<? if ($comment_min || $comment_max) { ?>onkeyup="check_byte('wr_content', 'char_count');"
<? }?> style='width:100%; ' class="textbox"></textarea>
            <? if ($comment_min || $comment_max) { ?><script type="text/javascript"> check_byte('wr_content', 'char_count'); </script>
<? }?>
        </td>     
  </tr>       
</table>
</form>
</td></tr></table>
</div>


<script type="text/javascript"> var md5_norobot_key = ''; </script>
<script type="text/javascript" src="<?="$g4[path]/js/prototype.js"?>"></script>
<script type="text/javascript">
function imageClick() {
    var url = "<?=$g4[bbs_path]?>/kcaptcha_session.php";
    var para = "";
    var myAjax = new Ajax.Request(
        url,
        {
            method: 'post',
            asynchronous: true,
            parameters: para,
            onComplete: imageClickResult
        });
}

function imageClickResult(req) {
    var result = req.responseText;
    var img = document.createElement("IMG");
    img.setAttribute("src", "<?=$g4[bbs_path]?>/kcaptcha_image.php?t=" + (new Date).getTime());
    document.getElementById('kcaptcha_image').src = img.getAttribute('src');

    md5_norobot_key = result;
}


var save_before = '';
var save_html = document.getElementById('comment_write').innerHTML;

function good_and_write()
{
    var f = document.fviewcomment;
    if (fviewcomment_submit(f)) {
        f.is_good.value = 1;
        f.submit();
    } else {
        f.is_good.value = 0;
    }
}

function fviewcomment_submit(f)
{
    var pattern = /(^\s*)|(\s*$)/g; // \s 공백 문자

    f.is_good.value = 0;

    var s;
    if (s = word_filter_check(document.getElementById('wr_content').value))
    {
        alert("내용에 금지단어('"+s+"')가 포함되어있습니다");
        document.getElementById('wr_content').focus();
        return false;
    }

    // 양쪽 공백 없애기
    var pattern = /(^\s*)|(\s*$)/g; // \s 공백 문자
    document.getElementById('wr_content').value = document.getElementById('wr_content').value.replace(pattern, "");
    if (char_min > 0 || char_max > 0)
    {
        check_byte('wr_content', 'char_count');
        var cnt = parseInt(document.getElementById('char_count').innerHTML);
        if (char_min > 0 && char_min > cnt)
        {
            alert("코멘트는 "+char_min+"글자 이상 쓰셔야 합니다.");
            return false;
        } else if (char_max > 0 && char_max < cnt)
        {
            alert("코멘트는 "+char_max+"글자 이하로 쓰셔야 합니다.");
            return false;
        }
    }
    else if (!document.getElementById('wr_content').value)
    {
        alert("코멘트를 입력하여 주십시오.");
        return false;
    }

    if (typeof(f.wr_name) != 'undefined')
    {
        f.wr_name.value = f.wr_name.value.replace(pattern, "");
        if (f.wr_name.value == '')
        {
            alert('이름이 입력되지 않았습니다.');
            f.wr_name.focus();
            return false;
        }
    }

    if (typeof(f.wr_password) != 'undefined')
    {
        f.wr_password.value = f.wr_password.value.replace(pattern, "");
        if (f.wr_password.value == '')
        {
            alert('패스워드가 입력되지 않았습니다.');
            f.wr_password.focus();
            return false;
        }
    }

    if (typeof(f.wr_key) != 'undefined')
    {
        if (hex_md5(f.wr_key.value) != md5_norobot_key)
        {
            alert('자동등록방지용 글자가 순서대로 입력되지 않았습니다.');
            f.wr_key.select();
            f.wr_key.focus();
            return false;
        }
    }

    return true;
}

function comment_box(comment_id, work)
{
    var el_id;
    // 코멘트 아이디가 넘어오면 답변, 수정
    if (comment_id)
    {
        if (work == 'c')
            el_id = 'reply_' + comment_id;
        else
            el_id = 'edit_' + comment_id;
    }
    else
        el_id = 'comment_write';

    if (save_before != el_id)
    {
        if (save_before)
        {
            document.getElementById(save_before).style.display = 'none';
            document.getElementById(save_before).innerHTML = '';
        }

        document.getElementById(el_id).style.display = '';
        document.getElementById(el_id).innerHTML = save_html;
        // 코멘트 수정
        if (work == 'cu')
        {
            document.getElementById('wr_content').value = document.getElementById('save_comment_' + comment_id).value;
            if (typeof char_count != 'undefined')
                check_byte('wr_content', 'char_count');
            if (document.getElementById('secret_comment_'+comment_id).value)
                document.getElementById('wr_secret').checked = true;
            else
                document.getElementById('wr_secret').checked = false;
        }

        document.getElementById('comment_id').value = comment_id;
        document.getElementById('w').value = work;

        save_before = el_id;
    }

    if (work == 'c') {
        <? if (!$is_member) { ?>imageClick();<? } ?>
    }
}

function comment_delete(url)
{
    if (confirm("이 코멘트를 삭제하시겠습니까?")) location.href = url;
}

comment_box('', 'c'); // 코멘트 입력폼이 보이도록 처리하기위해서 추가 (root님)
</script>

<? }?>

<? if($cwin==1) { ?></td><tr></table><div align="center"><a href="javascript:window.close();"><img src="<?=$board_skin_path?>/img/btn_close.gif" border="0" width="60" height="25"></a></div>
<? }?>

댓글 전체

전체 66,554 |RSS
그누4 질문답변 내용 검색

회원로그인

(주)에스아이알소프트 / 대표:홍석명 / (06211) 서울특별시 강남구 역삼동 707-34 한신인터밸리24 서관 1402호 / E-Mail: admin@sir.kr
사업자등록번호: 217-81-36347 / 통신판매업신고번호:2014-서울강남-02098호 / 개인정보보호책임자:김민섭(minsup@sir.kr)
© SIRSOFT