테스트 사이트 - 개발 중인 베타 버전입니다

댓글 달기 채택완료

YJK 8년 전 조회 6,437

댓글창에서 첨부파일을 넣을 수 있게 구현을 했습니다.

그런데 댓글에 댓글 적기를 누르면 자꾸 새로고침이 되는데 왜그럴까요?

 

</p><p><?php</p><p>if (!defined('_GNUBOARD_')) exit; // 개별 페이지 접근 불가</p><p> </p><p>$sql = " select * from $write_table where wr_parent = '$wr_id' and wr_is_comment = 1 order by wr_comment, wr_comment_reply ";</p><p>$result = sql_query($sql);</p><p>for ($i=0; $row=sql_fetch_array($result); $i++) </p><p>{</p><p>   if (!strstr($row[wr_option], "secret") ||</p><p>        $is_admin || </p><p>        ($row[mb_id]==$member[mb_id] && $member[mb_id])) {</p><p>        <span class="Apple-tab-span" style="white-space:pre">	</span></p><p>        $list[$i][cfile] = get_file($board['bo_table'], $row['wr_id']);</p><p>        </p><p>        if(!$list[$i][cfile][0][view]){ </p><p>        <span class="Apple-tab-span" style="white-space:pre">	</span></p><p>        <span class="Apple-tab-span" style="white-space:pre">	</span>/* 이미지가 아닌건 허용된확장자만 링크 */</p><p>        <span class="Apple-tab-span" style="white-space:pre">	</span>$sPermissionExt = "txt|csv|zip|tar";</p><p>        <span class="Apple-tab-span" style="white-space:pre">	</span></p><p>        <span class="Apple-tab-span" style="white-space:pre">	</span>if( preg_match("/\.($sPermissionExt)$/i", $list[$i][cfile][0][source])){ </p><p>        <span class="Apple-tab-span" style="white-space:pre">		</span></p><p>        <span class="Apple-tab-span" style="white-space:pre">		</span>$list[$i][cfile][0][view] = "<img src='{$board_skin_path}/img/icon_file.gif' align=absmiddle border='0'> <a href='".$list[$i][cfile][0][href]."'>".$list[$i][cfile][0][source]."</a>
";</p><p>        <span class="Apple-tab-span" style="white-space:pre">		</span>set_session("ss_view_{$bo_table}_{$row[wr_id]}" , TRUE );</p><p>        <span class="Apple-tab-span" style="white-space:pre">	</span>}<span class="Apple-tab-span" style="white-space:pre">	</span></p><p>        <span class="Apple-tab-span" style="white-space:pre">	</span></p><p>        }<span class="Apple-tab-span" style="white-space:pre">	</span></p><p>   }   </p><p>}</p><p> </p><p>?></p><p> </p><p><script></p><p>// 글자수 제한</p><p>var char_min = parseInt(<?php echo $comment_min ?>); // 최소</p><p>var char_max = parseInt(<?php echo $comment_max ?>); // 최대</p><p></script></p><p> </p><p><!-- 댓글 시작 { --></p><p> </p><p><section id="bo_vc"></p><p>    <h2>댓글목록</h2></p><p>    <?php</p><p>    $cmt_amt = count($list);</p><p>    for ($i=0; $i<$cmt_amt; $i++) {</p><p>        $comment_id = $list[$i]['wr_id'];</p><p>        $cmt_depth = ""; // 댓글단계</p><p>        $cmt_depth = strlen($list[$i]['wr_comment_reply']) * 20;</p><p>        $comment = $list[$i]['content'];</p><p>        /*</p><p>        if (strstr($list[$i]['wr_option'], "secret")) {</p><p>            $str = $str;</p><p>        }</p><p>        */</p><p>        $comment = 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>", $comment);</p><p>        $cmt_sv = $cmt_amt - $i + 1; // 댓글 헤더 z-index 재설정 ie8 이하 사이드뷰 겹침 문제 해결</p><p>     ?></p><p> </p><p>    <article id="c_<?php echo $comment_id ?>" <?php if ($cmt_depth) { ?>style="margin-left:<?php echo $cmt_depth ?>px;border-top-color:#e0e0e0"<?php } ?>></p><p>        <header style="z-index:<?php echo $cmt_sv; ?>"></p><p>            <h1><?php echo get_text($list[$i]['wr_name']); ?>님의 댓글</h1></p><p>            <?php echo $list[$i]['name'] ?></p><p>            <?php if ($cmt_depth) { ?><img src="<?php echo $board_skin_url ?>/img/icon_reply.gif" class="icon_reply" alt="댓글의 댓글"><?php } ?></p><p>            <!--<?php if ($is_ip_view) { ?></p><p>            아이피</p><p>            <span class="bo_vc_hdinfo"><?php echo $list[$i]['ip']; ?></span></p><p>            <?php } ?></p><p>            작성일--></p><p>            <span class="bo_vc_hdinfo"><time datetime="<?php echo date('Y-m-d\TH:i:s+09:00', strtotime($list[$i]['datetime'])) ?>"><?php echo $list[$i]['datetime'] ?></time></span></p><p>            <?php</p><p>            include(G5_SNS_PATH.'/view_comment_list.sns.skin.php');</p><p>            ?></p><p>        </header></p><p> </p><p>        <!-- 댓글 출력 --></p><p>        <p></p><p>            <?php if (strstr($list[$i]['wr_option'], "secret")) { ?><img src="<?php echo $board_skin_url; ?>/img/icon_secret.gif" alt="비밀글"><?php } ?></p><p><span class="Apple-tab-span" style="white-space:pre">			</span><?</p><p>                if($list[$i][cfile][0][view]){</p><p>                <span class="Apple-tab-span" style="white-space:pre">	</span>echo $list[$i][cfile][0][view]."
";</p><p>              <span class="Apple-tab-span" style="white-space:pre">	</span>}</p><p>                ?></p><p>                <?</p><p>                if (strstr($list[$i][wr_option], "secret")) echo "<span style='color:#ff6600;'>*</span> ";</p><p>                $str = $list[$i][content];</p><p>                if (strstr($list[$i][wr_option], "secret"))</p><p>                    $str = "<span class='small' style='color:#ff6600;'>$str</span>";</p><p> </p><p>                $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);</p><p>                // FLASH XSS 공격에 의해 주석 처리 - 110406</p><p>                //$str = preg_replace("/\[\<a\s.*href\=\"(http|https|ftp)\:\/\/([^[:space:]]+)\.(swf)\".*\<\/a\>\]/i", "<script>doc_write(flash_movie('$1://$2.$3'));</script>", $str);</p><p>                $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);</p><p>                echo $str;</p><p>                ?>       </p><p><span class="Apple-tab-span" style="white-space:pre">		</span></p></p><p> </p><p>                <span id='edit_<?=$comment_id?>' style='display:none;'></span><!-- 수정 --></p><p>                <span id='reply_<?=$comment_id?>' style='display:none;'></span><!-- 답변 --></p><p> </p><p>                <input type=hidden id='secret_comment_<?=$comment_id?>' value="<?=strstr($list[$i][wr_option],"secret")?>"></p><p>                <input type=hidden id='commentfile_<?=$comment_id?>' value="<?=$list[$i][cfile][0][file]?>"></p><p>                <textarea id='save_comment_<?=$comment_id?>' style='display:none;'><?=get_text($list[$i][content1], 0)?></textarea></p><p> </p><p>        <?php if($list[$i]['is_reply'] || $list[$i]['is_edit'] || $list[$i]['is_del']) {</p><p>            $query_string = clean_query_string($_SERVER['QUERY_STRING']);</p><p> </p><p>            if($w == 'cu') {</p><p>                $sql = " select wr_id, wr_content, mb_id from $write_table where wr_id = '$c_id' and wr_is_comment = '1' ";</p><p>                $cmt = sql_fetch($sql);</p><p>                if (!($is_admin || ($member['mb_id'] == $cmt['mb_id'] && $cmt['mb_id'])))</p><p>                    $cmt['wr_content'] = '';</p><p>                $c_wr_content = $cmt['wr_content'];</p><p>            }</p><p> </p><p>            $c_reply_href = './board.php?'.$query_string.'&amp;c_id='.$comment_id.'&amp;w=c#bo_vc_w';</p><p>            $c_edit_href = './board.php?'.$query_string.'&amp;c_id='.$comment_id.'&amp;w=cu#bo_vc_w';</p><p>         ?></p><p>        <footer></p><p>            <ul class="bo_vc_act"></p><p>                <?php if ($list[$i]['is_reply']) { ?><li><a href="<?php echo $c_reply_href;  ?>" onclick="comment_box('<?php echo $comment_id ?>', 'c'); return false;"><i class="fa fa-reply" aria-hidden="true"></i></a></li><?php } ?></p><p>                <?php if ($list[$i]['is_edit']) { ?><li><a href="<?php echo $c_edit_href;  ?>" onclick="comment_box('<?php echo $comment_id ?>', 'cu'); return false;"><i class="fa fa-pencil-square-o" aria-hidden="true"></i></a></li><?php } ?></p><p>                <?php if ($list[$i]['is_del'])  { ?><li><a href="<?php echo $list[$i]['del_link'];  ?>" onclick="return comment_delete();"><i class="fa fa-trash-o" aria-hidden="true"></i></a></li><?php } ?></p><p>            </ul></p><p>        </footer></p><p>        <?php } ?></p><p>    </article></p><p>    <?php } ?></p><p>    <?php if ($i == 0) { //댓글이 없다면 ?><p id="bo_vc_empty">등록된 댓글이 없습니다.</p><?php } ?></p><p> </p><p></section></p><p><!-- } 댓글 끝 --></p><p> </p><p><?php if ($is_comment_write) {</p><p>    if($w == '')</p><p>        $w = 'c';</p><p>?></p><p><!-- 댓글 쓰기 시작 { --></p><p><aside id="bo_vc_w"></p><p>    <h2></h2></p><p><form name="fviewcomment" method="post" action="./write_comment_update.php" onsubmit="return fviewcomment_submit(this);" autocomplete="off" style="margin:0px;" enctype="multipart/form-data"></p><p>    <input type="hidden" name="w" value="<?php echo $w ?>" id="w"></p><p>    <input type="hidden" name="bo_table" value="<?php echo $bo_table ?>"></p><p>    <input type="hidden" name="wr_id" value="<?php echo $wr_id ?>"></p><p>    <input type="hidden" name="comment_id" value="<?php echo $c_id ?>" id="comment_id"></p><p>    <input type="hidden" name="sca" value="<?php echo $sca ?>"></p><p>    <input type="hidden" name="sfl" value="<?php echo $sfl ?>"></p><p>    <input type="hidden" name="stx" value="<?php echo $stx ?>"></p><p>    <input type="hidden" name="spt" value="<?php echo $spt ?>"></p><p>    <input type="hidden" name="page" value="<?php echo $page ?>"></p><p>    <input type="hidden" name="is_good" value=""></p><p><span class="Apple-tab-span" style="white-space:pre">	</span><input type="hidden" name='cwin'        value='<?=$cwin?>'></p><p> </p><p> </p><p><div class="comment_wrap"></p><p><span class="Apple-tab-span" style="white-space:pre">		</span><div class="btn_srt"></p><p><span class="Apple-tab-span" style="white-space:pre">			</span><tr></p><p><span class="Apple-tab-span" style="white-space:pre">				</span><th scope="row"><label for="wr_secret"><i class="fa fa-lock" aria-hidden="true"></i> 비밀글</label></th></p><p><span class="Apple-tab-span" style="white-space:pre">				</span><td><input type="checkbox" name="wr_secret" value="secret" id="wr_secret"></td></p><p><span class="Apple-tab-span" style="white-space:pre">			</span></tr></p><p><span class="Apple-tab-span" style="white-space:pre">		</span></div></p><p><span class="Apple-tab-span" style="white-space:pre">	</span><div class="comment_con"></p><p><span class="Apple-tab-span" style="white-space:pre">		</span><?php if ($is_guest) { ?></p><p><span class="Apple-tab-span" style="white-space:pre">		</span><span></p><p><span class="Apple-tab-span" style="white-space:pre">			</span><label for="wr_name">이름<strong class="sound_only"> 필수</strong></label></p><p><span class="Apple-tab-span" style="white-space:pre">			</span><input type="text" name="wr_name" value="<?php echo get_cookie("ck_sns_name"); ?>" id="wr_name" required class="frm_input required" size="5" maxLength="20"></p><p><span class="Apple-tab-span" style="white-space:pre">		</span></span></p><p><span class="Apple-tab-span" style="white-space:pre">		</span><span></p><p><span class="Apple-tab-span" style="white-space:pre">			</span><label for="wr_password">비밀번호<strong class="sound_only"> 필수</strong></label></p><p><span class="Apple-tab-span" style="white-space:pre">			</span><input type="password" name="wr_password" id="wr_password" required class="frm_input required" size="10" maxLength="20"></p><p><span class="Apple-tab-span" style="white-space:pre">		</span></span></p><p><span class="Apple-tab-span" style="white-space:pre">		</span><?php } ?></p><p><span class="Apple-tab-span" style="white-space:pre">	</span></div></p><p></div></p><p><span class="Apple-tab-span" style="white-space:pre">	</span><div class="comment_con"><span class="Apple-tab-span" style="white-space:pre">	</span></p><p><span class="Apple-tab-span" style="white-space:pre">		</span> <?php if ($comment_min || $comment_max) { ?><strong id="char_cnt"><span id="char_count"></span>글자</strong><?php } ?></p><p>                <textarea id="wr_content" name="wr_content" maxlength="10000" required class="required" title="내용"</p><p>                <?php if ($comment_min || $comment_max) { ?>onkeyup="check_byte('wr_content', 'char_count');"<?php } ?>><?php echo $c_wr_content;  ?></textarea></p><p>                <?php if ($comment_min || $comment_max) { ?><script> check_byte('wr_content', 'char_count'); </script><?php } ?></p><p><span class="Apple-tab-span" style="white-space:pre">		</span></p><p><span class="Apple-tab-span" style="white-space:pre">				</span><script></p><p>                $(document).on( "keyup change", "textarea#wr_content[maxlength]", function(){</p><p>                    var str = $(this).val()</p><p>                    var mx = parseInt($(this).attr("maxlength"))</p><p>                    if (str.length > mx) {</p><p>                        $(this).val(str.substr(0, mx));</p><p>                        return false;</p><p>                    }</p><p>                });</p><p>                </script></p><p> </p><p><span class="Apple-tab-span" style="white-space:pre">			</span><input type="submit" id="btn_submit" class="btn_submit" value="&#xf075;" style="font-family: FontAwesome; font-size:25px;"></p><p> </p><p><span class="Apple-tab-span" style="white-space:pre">			</span><div style="clear:both"></div></p><p><span class="Apple-tab-span" style="white-space:pre">				</span><div class="comment_img_box"></p><p><span class="Apple-tab-span" style="white-space:pre">				</span><input type=file class="jfilestyle" data-buttontext="Find file"  id="jfilestyle-0" name="wr_commentfile"  ></p><p><span class="Apple-tab-span" style="white-space:pre">				</span><span id="delspan" style='display:none'><input type=checkbox name=wr_commentfile_del value=Y >파일삭제</span></p><p><span class="Apple-tab-span" style="white-space:pre">				</span><script type="text/javascript" src="/js/jquery.filestyle.js" charset="utf-8"></script></p><p><span class="Apple-tab-span" style="white-space:pre">			</span></div></p><p><span class="Apple-tab-span" style="white-space:pre">			</span><div style="clear:both"></div></p><p> </p><p><span class="Apple-tab-span" style="white-space:pre">	</span></div></p><p> </p><p>    </form></p><p></aside></p><p> </p><p> </p><p><script></p><p>var save_before = '';</p><p>var save_html = document.getElementById('bo_vc_w').innerHTML;</p><p> </p><p>function good_and_write()</p><p>{</p><p>    var f = document.fviewcomment;</p><p>    if (fviewcomment_submit(f)) {</p><p>        f.is_good.value = 1;</p><p>        f.submit();</p><p>    } else {</p><p>        f.is_good.value = 0;</p><p>    }</p><p>}</p><p> </p><p>function fviewcomment_submit(f)</p><p>{</p><p>    var pattern = /(^\s*)|(\s*$)/g; // \s 공백 문자</p><p> </p><p>    f.is_good.value = 0;</p><p> </p><p>    var subject = "";</p><p>    var content = "";</p><p>    $.ajax({</p><p>        url: g5_bbs_url+"/ajax.filter.php",</p><p>        type: "POST",</p><p>        data: {</p><p>            "subject": "",</p><p>            "content": f.wr_content.value</p><p>        },</p><p>        dataType: "json",</p><p>        async: false,</p><p>        cache: false,</p><p>        success: function(data, textStatus) {</p><p>            subject = data.subject;</p><p>            content = data.content;</p><p>        }</p><p>    });</p><p> </p><p>    if (content) {</p><p>        alert("내용에 금지단어('"+content+"')가 포함되어있습니다");</p><p>        f.wr_content.focus();</p><p>        return false;</p><p>    }</p><p> </p><p>    // 양쪽 공백 없애기</p><p>    var pattern = /(^\s*)|(\s*$)/g; // \s 공백 문자</p><p>    document.getElementById('wr_content').value = document.getElementById('wr_content').value.replace(pattern, "");</p><p>    if (char_min > 0 || char_max > 0)</p><p>    {</p><p>        check_byte('wr_content', 'char_count');</p><p>        var cnt = parseInt(document.getElementById('char_count').innerHTML);</p><p>        if (char_min > 0 && char_min > cnt)</p><p>        {</p><p>            alert("댓글은 "+char_min+"글자 이상 쓰셔야 합니다.");</p><p>            return false;</p><p>        } else if (char_max > 0 && char_max < cnt)</p><p>        {</p><p>            alert("댓글은 "+char_max+"글자 이하로 쓰셔야 합니다.");</p><p>            return false;</p><p>        }</p><p>    }</p><p>    else if (!document.getElementById('wr_content').value)</p><p>    {</p><p>        alert("댓글을 입력하여 주십시오.");</p><p>        return false;</p><p>    }</p><p> </p><p>    if (typeof(f.wr_name) != 'undefined')</p><p>    {</p><p>        f.wr_name.value = f.wr_name.value.replace(pattern, "");</p><p>        if (f.wr_name.value == '')</p><p>        {</p><p>            alert('이름이 입력되지 않았습니다.');</p><p>            f.wr_name.focus();</p><p>            return false;</p><p>        }</p><p>    }</p><p> </p><p>    if (typeof(f.wr_password) != 'undefined')</p><p>    {</p><p>        f.wr_password.value = f.wr_password.value.replace(pattern, "");</p><p>        if (f.wr_password.value == '')</p><p>        {</p><p>            alert('비밀번호가 입력되지 않았습니다.');</p><p>            f.wr_password.focus();</p><p>            return false;</p><p>        }</p><p>    }</p><p> </p><p>    <?php if($is_guest) echo chk_captcha_js();  ?></p><p> </p><p>    set_comment_token(f);</p><p> </p><p>    document.getElementById("btn_submit").disabled = "disabled";</p><p> </p><p>    return true;</p><p>}</p><p> </p><p>function comment_box(comment_id, work)</p><p>{</p><p> var el_id;</p><p>    var cf_id;</p><p>    // 코멘트 아이디가 넘어오면 답변, 수정</p><p>    if (comment_id)</p><p>    {</p><p>        if (work == 'c')</p><p>            el_id = 'reply_' + comment_id;</p><p>        else</p><p>            el_id = 'edit_' + comment_id;</p><p>    }</p><p>    else</p><p>        el_id = 'comment_write';</p><p>    </p><p>    </p><p>    cf_id = 'commentfile_' + comment_id;</p><p> </p><p> </p><p>    if (save_before != el_id)</p><p>    {</p><p>        if (save_before)</p><p>        {</p><p>            document.getElementById(save_before).style.display = 'none';</p><p>            document.getElementById(save_before).innerHTML = '';</p><p>        }</p><p> </p><p>        document.getElementById(el_id).style.display = '';</p><p>        document.getElementById(el_id).innerHTML = save_html;</p><p>        // 댓글 수정</p><p>        if (work == 'cu')</p><p>        {</p><p>            document.getElementById('wr_content').value = document.getElementById('save_comment_' + comment_id).value;</p><p>            if (typeof char_count != 'undefined')</p><p>                check_byte('wr_content', 'char_count');</p><p>            if (document.getElementById('secret_comment_'+comment_id).value)</p><p>                document.getElementById('wr_secret').checked = true;</p><p>            else</p><p>                document.getElementById('wr_secret').checked = false;</p><p>        }</p><p> </p><p>        document.getElementById('comment_id').value = comment_id;</p><p>        document.getElementById('w').value = work;</p><p> </p><p>        if(save_before)</p><p>            $("#captcha_reload").trigger("click");</p><p> </p><p>        save_before = el_id;</p><p>    }</p><p>    if (typeof(wrestInitialized) != 'undefined')</p><p>        wrestInitialized();</p><p> </p><p>    //jQuery(this).kcaptcha_load();</p><p>    if (comment_id && work == 'c')</p><p>        $.kcaptcha_run();</p><p>        </p><p>    if (comment_id){</p><p><span class="Apple-tab-span" style="white-space:pre">	</span>    if(document.getElementById(cf_id).value && work =='cu'){</p><p><span class="Apple-tab-span" style="white-space:pre">	</span>    <span class="Apple-tab-span" style="white-space:pre">	</span>    document.getElementById('delspan').style.display = "inline-block";</p><p><span class="Apple-tab-span" style="white-space:pre">	</span>    }</p><p>    }<span class="Apple-tab-span" style="white-space:pre">	</span>    </p><p>}</p><p> </p><p>function comment_delete()</p><p>{</p><p>    return confirm("이 댓글을 삭제하시겠습니까?");</p><p>}</p><p> </p><p>comment_box('', 'c'); // 댓글 입력폼이 보이도록 처리하기위해서 추가 (root님)</p><p> </p><p><?php if($board['bo_use_sns'] && ($config['cf_facebook_appid'] || $config['cf_twitter_key'])) { ?></p><p>// sns 등록</p><p>$(function() {</p><p>    $("#bo_vc_send_sns").load(</p><p>        "<?php echo G5_SNS_URL; ?>/view_comment_write.sns.skin.php?bo_table=<?php echo $bo_table; ?>",</p><p>        function() {</p><p>            save_html = document.getElementById('bo_vc_w').innerHTML;</p><p>        }</p><p>    );</p><p>});</p><p><?php } ?></p><p></script></p><p><?php } ?></p><p><!-- } 댓글 쓰기 끝 --></p><p>

댓글을 작성하려면 로그인이 필요합니다.

답변 1개

채택된 답변
+20 포인트
플라이
8년 전

새로고침이 된다는게 입력후에 새로고첨이 되고 노출이 된다는건가요? 아니면 그냥 새로고침만 반복적으로 발생한다는 건가요? 만약 새로고침이 계속 발생되는 부분이라면 뭔가 스크립트나 페이지 이동이 이뤄지는 부분의 스크립트가 계속 일어난다는 건데요 그 부분은 확인이 가능하다면 사이트를 통해 확인해 봐야 할듯 싶습니다.

로그인 후 평가할 수 있습니다

답변에 대한 댓글 1개

Y
YJK
8년 전
그냥
<li><a href="<?php echo $c_reply_href; ?>" onclick="comment_box('<?php echo $comment_id ?>', 'c'); return false;"><i class="fa fa-reply" aria-hidden="true"></i></a></li>
댓글의 댓글을 적으려고 이부분만 누르기만 하면 새로고침이 됩니다 ㅠ

댓글을 작성하려면 로그인이 필요합니다.

답변을 작성하려면 로그인이 필요합니다.

로그인