답변 2개
채택된 답변
+20 포인트
10년 전
제 글 다시 잘 읽어보세요 빠진 사항들이 있네요.
제가 테스트 한 원본 올려봅니다.
</p><p><?php</p><p>if (!defined('_GNUBOARD_')) exit; // 개별 페이지 접근 불가</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><script></p><p>function check(){</p><p>var<span class="Apple-tab-span" style="white-space:pre"> </span>is_guest = <?=$is_guest?>;</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(is_guest) {</p><p><span class="Apple-tab-span" style="white-space:pre"> </span>alert('로그인 후 작성가능합니다.');</p><p><span class="Apple-tab-span" style="white-space:pre"> </span>location.href="./login.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></p><p>}</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> <?php echo $comment ?></p><p> </p></p><p> </p><p> <span id="edit_<?php echo $comment_id ?>"></span><!-- 수정 --></p><p> <span id="reply_<?php echo $comment_id ?>"></span><!-- 답변 --></p><p> </p><p> <input type="hidden" value="<?php echo strstr($list[$i]['wr_option'],"secret") ?>" id="secret_comment_<?php echo $comment_id ?>"></p><p> <textarea id="save_comment_<?php echo $comment_id ?>" style="display:none"><?php echo 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 = str_replace("&", "&", $_SERVER['QUERY_STRING']);</p><p> </p><p> if($w == 'cu') {</p><p> $sql = " select wr_id, wr_content from $write_table where wr_id = '$c_id' and wr_is_comment = '1' ";</p><p> $cmt = sql_fetch($sql);</p><p> $c_wr_content = $cmt['wr_content'];</p><p> }</p><p> </p><p> $c_reply_href = './board.php?'.$query_string.'&c_id='.$comment_id.'&w=c#bo_vc_w';</p><p> $c_edit_href = './board.php?'.$query_string.'&c_id='.$comment_id.'&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;">답변</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;">수정</a></li><?php } ?></p><p> <?php if ($list[$i]['is_del']) { ?><li><a href="<?php echo $list[$i]['del_link']; ?>" onclick="return comment_delete();">삭제</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> </p><p><!-- 댓글 쓰기 시작 { --></p><p><aside id="bo_vc_w"></p><p> <h2>댓글쓰기</h2></p><p> <form name="fviewcomment" action="./write_comment_update.php" onsubmit="return fviewcomment_submit(this);" method="post" autocomplete="off"></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> </p><p> <div class="tbl_frm01 tbl_wrap"></p><p> <table></p><p> <tbody></p><p> </p><p> <?php</p><p> if($board['bo_use_sns'] && ($config['cf_facebook_appid'] || $config['cf_twitter_key'])) {</p><p> ?></p><p> <tr></p><p> <th scope="row">SNS 동시등록</th></p><p> <td id="bo_vc_send_sns"></td></p><p> </tr></p><p> <?php</p><p> }</p><p> ?></p><p> </p><p> <tr></p><p> <th scope="row">내용</th></p><p> <td></p><p> <?php if ($comment_min || $comment_max) { ?><strong id="char_cnt"><span id="char_count"></span>글자</strong><?php } ?></p><p> <textarea onclick="javascript:check();" 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> <script></p><p> $("textarea#wr_content[maxlength]").live("keyup change", 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><span class="Apple-tab-span" style="white-space:pre"> </span></p><p> </td></p><p> </tr></p><p> </tbody></p><p> </table></p><p> </div></p><p> </p><p> <div class="btn_confirm"></p><p> <input type="submit" id="btn_submit" class="btn_submit" value="댓글등록"></p><p> </div></p><p> </p><p> </form></p><p></aside></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> 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> // 댓글 아이디가 넘어오면 답변, 수정</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 = 'bo_vc_w';</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>}</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> </p><p><!-- } 댓글 쓰기 끝 --> </p><p>
로그인 후 평가할 수 있습니다
답변에 대한 댓글 1개
�
뻐꾸기
10년 전
댓글을 작성하려면 로그인이 필요합니다.
10년 전
요점은 댓글창은 무조건 보이고 비회원은 경고창 후 로그인 페이지로 회원은 작성되고 맞죠?
0. 댓글쓰기 권한 2 회원으로 수정
1. 해당 스킨의 view_comment.skin.php 스킨 상단에 아래 스크립트 추가
</p><p><script></p><p>function check(){</p><p>var is_guest = <?=$is_guest?>;</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(is_guest) {</p><p><span class="Apple-tab-span" style="white-space:pre"> </span>alert('로그인 후 작성가능합니다.');</p><p><span class="Apple-tab-span" style="white-space:pre"> </span>location.href="./login.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></p><p>}</p><p></script> </p><p>
댓글 입력필드 <textarea onclick="javascript:check();" ............ > onclick 추가.
2. 댓글 쓰는 폼을 감싸고 있는 함수 삭제 (그래야 댓글창 무조건 출력)
</p><p><b><?php if ($is_guest) {</b></p><p><b> if($w == '')</b></p><p><b> $w = 'c';</b></p><p><b>?></b></p><p><!-- 댓글 쓰기 시작 { --> </p><p>.</p><p>.</p><p>.</p><p>.</p><p><b><?php } ?></b></p><p><!-- } 댓글 쓰기 끝 --> </p><p>
3. 아래 비회원작성 필드 삭제
</p><p><?php if ($is_guest) { ?></p><p> <tr></p><p> <th scope="row"><label for="wr_name">이름<strong class="sound_only"> 필수</strong></label></th></p><p> <td><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"></td></p><p> </tr></p><p> <tr></p><p> <th scope="row"><label for="wr_password">비밀번호<strong class="sound_only"> 필수</strong></label></th></p><p> <td><input type="password" name="wr_password" id="wr_password" required class="frm_input required" size="10" maxLength="20"></td></p><p> </tr></p><p> <?php } ?></p><p> <tr></p><p> <th scope="row"><label for="wr_secret">비밀글사용</label></th></p><p> <td><input type="checkbox" name="wr_secret" value="secret" id="wr_secret"></td></p><p> </tr></p><p> <?php if ($is_guest) { ?></p><p> <tr></p><p> <th scope="row">자동등록방지</th></p><p> <td><?php echo $captcha_html; ?></td></p><p> </tr></p><p> <?php } ?> </p><p>
이렇게 하면 깔끔하게 무조건 댓글창만 보이게 되며 비회원이 클릭시 로그인 페이지로 이동시키며
회원은 그냥 작성 됩니다.
로그인 후 평가할 수 있습니다
답변에 대한 댓글 1개
�
뻐꾸기
10년 전
다음과 같이 해 보았으나 기능이 적용이 이루어지지 않고 있습니다.
게시판 관리자에서는 댓글 권한을 2로 설정해노았습니다.
<?php if ($is_guest) {
if($w == '')
$w = 'c';
?>
<!-- 댓글 쓰기 시작 { -->
<aside id="bo_vc_w">
<h2>댓글쓰기</h2>
<form name="fviewcomment" action="./write_comment_update.php" onsubmit="return fviewcomment_submit(this);" method="post" autocomplete="off">
<input type="hidden" name="w" value="<?php echo $w ?>" id="w">
<input type="hidden" name="bo_table" value="<?php echo $bo_table ?>">
<input type="hidden" name="wr_id" value="<?php echo $wr_id ?>">
<input type="hidden" name="comment_id" value="<?php echo $c_id ?>" id="comment_id">
<input type="hidden" name="sca" value="<?php echo $sca ?>">
<input type="hidden" name="sfl" value="<?php echo $sfl ?>">
<input type="hidden" name="stx" value="<?php echo $stx ?>">
<input type="hidden" name="spt" value="<?php echo $spt ?>">
<input type="hidden" name="page" value="<?php echo $page ?>">
<input type="hidden" name="is_good" value="">
<div class="tbl_frm01 tbl_wrap">
<table class="comment_maque11">
<tbody>
<?php
if($board['bo_use_sns'] && ($config['cf_facebook_appid'] || $config['cf_twitter_key'])) {
?>
<tr>
<th scope="row">SNS 동시등록</th>
<td id="bo_vc_send_sns"></td>
</tr>
<?php
}
?>
<tr>
<th scope="row">댓글내용</th>
<td>
<?php if ($comment_min || $comment_max) { ?><strong id="char_cnt"><span id="char_count"></span>글자</strong><?php } ?>
<textarea id="wr_content" name="wr_content" maxlength="10000" required class="required" title="내용"
<?php if ($comment_min || $comment_max) { ?>onkeyup="check_byte('wr_content', 'char_count');"<?php } ?>><?php echo $c_wr_content; ?></textarea>
<?php if ($comment_min || $comment_max) { ?><script> check_byte('wr_content', 'char_count'); </script><?php } ?>
<script>
$("textarea#wr_content[maxlength]").live("keyup change", function() {
var str = $(this).val()
var mx = parseInt($(this).attr("maxlength"))
if (str.length > mx) {
$(this).val(str.substr(0, mx));
return false;
}
});
</script>
</td>
</tr>
</tbody>
</table>
</div>
<div class="btn_confirm">
<input type="submit" id="btn_submit" class="btn_submit_ideaing" value="댓글등록">
</div>
</form>
</aside>
<script>
var save_before = '';
var save_html = document.getElementById('bo_vc_w').innerHTML;
function check(){
var is_guest = <?=$is_guest?>;
if(is_guest) {
alert('로그인 후 작성가능합니다.');
location.href="./login.php";
}
}
내용이 길어서 아래 내용은 생략
</script>
<?php } ?>
<!-- } 댓글 쓰기 끝 -->
게시판 관리자에서는 댓글 권한을 2로 설정해노았습니다.
<?php if ($is_guest) {
if($w == '')
$w = 'c';
?>
<!-- 댓글 쓰기 시작 { -->
<aside id="bo_vc_w">
<h2>댓글쓰기</h2>
<form name="fviewcomment" action="./write_comment_update.php" onsubmit="return fviewcomment_submit(this);" method="post" autocomplete="off">
<input type="hidden" name="w" value="<?php echo $w ?>" id="w">
<input type="hidden" name="bo_table" value="<?php echo $bo_table ?>">
<input type="hidden" name="wr_id" value="<?php echo $wr_id ?>">
<input type="hidden" name="comment_id" value="<?php echo $c_id ?>" id="comment_id">
<input type="hidden" name="sca" value="<?php echo $sca ?>">
<input type="hidden" name="sfl" value="<?php echo $sfl ?>">
<input type="hidden" name="stx" value="<?php echo $stx ?>">
<input type="hidden" name="spt" value="<?php echo $spt ?>">
<input type="hidden" name="page" value="<?php echo $page ?>">
<input type="hidden" name="is_good" value="">
<div class="tbl_frm01 tbl_wrap">
<table class="comment_maque11">
<tbody>
<?php
if($board['bo_use_sns'] && ($config['cf_facebook_appid'] || $config['cf_twitter_key'])) {
?>
<tr>
<th scope="row">SNS 동시등록</th>
<td id="bo_vc_send_sns"></td>
</tr>
<?php
}
?>
<tr>
<th scope="row">댓글내용</th>
<td>
<?php if ($comment_min || $comment_max) { ?><strong id="char_cnt"><span id="char_count"></span>글자</strong><?php } ?>
<textarea id="wr_content" name="wr_content" maxlength="10000" required class="required" title="내용"
<?php if ($comment_min || $comment_max) { ?>onkeyup="check_byte('wr_content', 'char_count');"<?php } ?>><?php echo $c_wr_content; ?></textarea>
<?php if ($comment_min || $comment_max) { ?><script> check_byte('wr_content', 'char_count'); </script><?php } ?>
<script>
$("textarea#wr_content[maxlength]").live("keyup change", function() {
var str = $(this).val()
var mx = parseInt($(this).attr("maxlength"))
if (str.length > mx) {
$(this).val(str.substr(0, mx));
return false;
}
});
</script>
</td>
</tr>
</tbody>
</table>
</div>
<div class="btn_confirm">
<input type="submit" id="btn_submit" class="btn_submit_ideaing" value="댓글등록">
</div>
</form>
</aside>
<script>
var save_before = '';
var save_html = document.getElementById('bo_vc_w').innerHTML;
function check(){
var is_guest = <?=$is_guest?>;
if(is_guest) {
alert('로그인 후 작성가능합니다.');
location.href="./login.php";
}
}
내용이 길어서 아래 내용은 생략
</script>
<?php } ?>
<!-- } 댓글 쓰기 끝 -->
댓글을 작성하려면 로그인이 필요합니다.
답변을 작성하려면 로그인이 필요합니다.
로그인
해결되였습니다.