update and fix codes

This commit is contained in:
Amberstone 2024-12-11 02:10:57 +09:00
parent 97f1be9902
commit f539fb454d
Signed by: amber
GPG key ID: 094B0E55F98D8BF1
12 changed files with 1167 additions and 1145 deletions

View file

@ -1,4 +1,3 @@
<? <?php
$g5_path = "../../.."; $g5_path = "../../..";
include_once("$g5_path/common.php"); include_once "$g5_path/common.php";
?>

View file

@ -1,72 +1,71 @@
<? <?php
include_once("./_common.php"); include_once "./_common.php";
if (!function_exists('convert_charset')) if (!function_exists('convert_charset'))
{ {
/* /*
----------------------------------------------------------- -----------------------------------------------------------
Charset 변환하는 함수 Charset 변환하는 함수
----------------------------------------------------------- -----------------------------------------------------------
iconv 함수가 있으면 iconv 변환하고 iconv 함수가 있으면 iconv 변환하고
없으면 mb_convert_encoding 함수를 사용한다. 없으면 mb_convert_encoding 함수를 사용한다.
둘다 없으면 사용할 없다. 둘다 없으면 사용할 없다.
*/ */
function convert_charset($from_charset, $to_charset, $str) function convert_charset($from_charset, $to_charset, $str)
{ {
if( function_exists('iconv') ) if( function_exists('iconv') )
return iconv($from_charset, $to_charset, $str); return iconv($from_charset, $to_charset, $str);
elseif( function_exists('mb_convert_encoding') ) elseif( function_exists('mb_convert_encoding') )
return mb_convert_encoding($str, $to_charset, $from_charset); return mb_convert_encoding($str, $to_charset, $from_charset);
else else
die("Not found 'iconv' or 'mbstring' library in server."); die("Not found 'iconv' or 'mbstring' library in server.");
} }
} }
header("Content-Type: text/html; charset=$g5['charset']"); header("Content-Type: text/html; charset={$g5['charset']}");
$subject = strtolower($_POST['subject']); $subject = strtolower($_POST['subject']);
$content = strtolower(strip_tags($_POST['content'])); $content = strtolower(strip_tags($_POST['content']));
//euc-kr 일 경우 $config['cf_filter'] 를 utf-8로 변환한다. //euc-kr 일 경우 $config['cf_filter'] 를 utf-8로 변환한다.
if (strtolower($g5['charset']) == 'euc-kr') if (strtolower($g5['charset']) == 'euc-kr')
{ {
//$subject = convert_charset('utf-8', 'cp949', $subject); //$subject = convert_charset('utf-8', 'cp949', $subject);
//$content = convert_charset('utf-8', 'cp949', $content); //$content = convert_charset('utf-8', 'cp949', $content);
$config['cf_filter'] = convert_charset('cp949', 'utf-8', $config['cf_filter']); $config['cf_filter'] = convert_charset('cp949', 'utf-8', $config['cf_filter']);
} }
//$filter = explode(",", strtolower(trim($config['cf_filter']))); //$filter = explode(",", strtolower(trim($config['cf_filter'])));
// strtolower 에 의한 한글 변형으로 아래 코드로 대체 (곱슬최씨님이 알려 주셨습니다.) // strtolower 에 의한 한글 변형으로 아래 코드로 대체 (곱슬최씨님이 알려 주셨습니다.)
$filter = explode(",", trim($config['cf_filter'])); $filter = explode(",", trim($config['cf_filter']));
for ($i=0; $i<count($filter); $i++) for ($i=0; $i<count($filter); $i++)
{ {
$str = $filter[$i]; $str = $filter[$i];
// 제목 필터링 (찾으면 중지) // 제목 필터링 (찾으면 중지)
$subj = ""; $subj = "";
$pos = strpos($subject, $str); $pos = strpos($subject, $str);
if ($pos !== false) if ($pos !== false)
{ {
if (strtolower($g5['charset']) == 'euc-kr') if (strtolower($g5['charset']) == 'euc-kr')
$subj = convert_charset('utf-8', 'cp949', $str);//cp949 로 변환해서 반환 $subj = convert_charset('utf-8', 'cp949', $str);//cp949 로 변환해서 반환
else else
$subj = $str; $subj = $str;
break; break;
} }
// 내용 필터링 (찾으면 중지) // 내용 필터링 (찾으면 중지)
$cont = ""; $cont = "";
$pos = strpos($content, $str); $pos = strpos($content, $str);
if ($pos !== false) if ($pos !== false)
{ {
if (strtolower($g5['charset']) == 'euc-kr') if (strtolower($g5['charset']) == 'euc-kr')
$cont = convert_charset('utf-8', 'cp949', $str);//cp949 로 변환해서 반환 $cont = convert_charset('utf-8', 'cp949', $str);//cp949 로 변환해서 반환
else else
$cont = $str; $cont = $str;
break; break;
} }
} }
die("{\"subject\":\"$subj\",\"content\":\"$cont\"}"); die("{\"subject\":\"$subj\",\"content\":\"$cont\"}");
?>

View file

@ -1,17 +1,14 @@
<? <?php
// 수정, 삭제 링크 // 수정, 삭제 링크
$update_href = $delete_href = ""; $update_href = $delete_href = "";
// 로그인중이고 자신의 글이라면 또는 관리자라면 패스워드를 묻지 않고 바로 수정, 삭제 가능 // 로그인중이고 자신의 글이라면 또는 관리자라면 패스워드를 묻지 않고 바로 수정, 삭제 가능
if (($member['mb_id'] && ($member['mb_id'] == $write['mb_id'])) || $is_admin) { if (($member['mb_id'] && ($member['mb_id'] == $write['mb_id'])) || $is_admin) {
$update_href = "./write.php?w=u&bo_table=$bo_table&wr_id={$lists[$ii]['wr_id']}&page=$page" . $qstr; $update_href = "./write.php?w=u&bo_table=$bo_table&wr_id={$lists[$ii]['wr_id']}&page=$page" . $qstr;
$delete_href = "javascript:del('./delete.php?bo_table=$bo_table&wr_id={$lists[$ii]['wr_id']}&page=$page".urldecode($qstr)."');"; $delete_href = "javascript:del('./delete.php?bo_table=$bo_table&wr_id={$lists[$ii]['wr_id']}&page=$page" . urldecode($qstr) . "');";
if ($is_admin) if ($is_admin) {
{ $delete_href = "javascript:del('./delete.php?bo_table=$bo_table&wr_id={$lists[$ii]['wr_id']}&token=$token&page=$page" . urldecode($qstr) . "');";
$delete_href = "javascript:del('./delete.php?bo_table=$bo_table&wr_id={$lists[$ii]['wr_id']}&token=$token&page=$page".urldecode($qstr)."');"; }
} } else if (!$write['mb_id']) { // 회원이 쓴 글이 아니라면
} $update_href = "./password.php?w=u&bo_table=$bo_table&wr_id={$lists[$ii]['wr_id']}&page=$page" . $qstr;
else if (!$write['mb_id']) { // 회원이 쓴 글이 아니라면 $delete_href = "./password.php?w=d&bo_table=$bo_table&wr_id={$lists[$ii]['wr_id']}&page=$page" . $qstr;
$update_href = "./password.php?w=u&bo_table=$bo_table&wr_id={$lists[$ii]['wr_id']}&page=$page" . $qstr; }
$delete_href = "./password.php?w=d&bo_table=$bo_table&wr_id={$lists[$ii]['wr_id']}&page=$page" . $qstr;
}
?>

View file

@ -1,306 +1,332 @@
<? <?php
if (!defined("_GNUBOARD_")) exit; // 개별 페이지 접근 불가 if (!defined("_GNUBOARD_"))
exit;
add_stylesheet('<link rel="stylesheet" href="'.$board_skin_url.'/style.css">', 0);
if($is_admin) set_session("ss_delete_token", $token = uniqid(time())); add_stylesheet('<link rel="stylesheet" href="' . $board_skin_url . '/style.css">', 0);
if ($is_admin)
if($is_member) { set_session("ss_delete_token", $token = uniqid(time()));
$comment_token = uniqid(time());
set_session('ss_comment_token', $comment_token); if ($is_member) {
} $comment_token = uniqid(time());
set_session('ss_comment_token', $comment_token);
$is_comment_write = false; }
if($board['bo_table_width']==0) $width="100%"; $is_comment_write = false;
?>
if ($board['bo_table_width'] == 0)
$width = "100%";
<div id="page_board_content" style="max-width:<?php echo $width; ?>;margin: 0 auto;"> ?>
<!-- 상단 공지 부분 --> <div id="page_board_content" style="max-width:<?php echo $width; ?>;margin: 0 auto;">
<? if($board['bo_content_head']) { ?>
<div class="board-notice theme-box">
<?=stripslashes($board['bo_content_head']);?> <!-- 상단 공지 부분 -->
</div> <?php if ($board['bo_content_head']) { ?>
<hr class="padding" /> <div class="board-notice theme-box">
<? } ?> <?= stripslashes($board['bo_content_head']); ?>
</div>
<!-- 버튼 링크 --> <hr class="padding" />
<? if($admin_href){?><div class="adm-box"><a href="<?=$admin_href?>" class="ui-btn admin" target="_blank">관리자</a></div><?}?> <?php } ?>
<div class="ui-memo-list theme-box "> <!-- 버튼 링크 -->
<div class="ui-top"><? if ($write_href) { <?php if ($admin_href) { ?>
?><div class="ui-write-area"> <div class="adm-box"><a href="<?= $admin_href ?>" class="ui-btn admin" target="_blank">관리자</a></div><?php } ?>
<? include ($board_skin_path."/write.php"); ?>
</div><? } <div class="ui-memo-list theme-box ">
?><div class="search-box"> <div class="ui-top"><?php if ($write_href) {
<form name="fsearch" method="get" style="margin:0px;"> ?>
<input type="hidden" name="bo_table" value="<?=$bo_table?>"> <div class="ui-write-area">
<input type="hidden" name="sca" value="<?=$sca?>"> <?php include $board_skin_path . "/write.php"; ?>
<input type="hidden" name="sfl" value='wr_subject||wr_content'> </div><?php }
<input type="hidden" name="sop" value="and"> ?>
<div class="search-box">
<input type="text" name="stx" itemname="검색어" value="<?=$stx?>" ><??><button type="submit" class="ui-btn">?</button> <form name="fsearch" method="get" style="margin:0px;">
</form> <input type="hidden" name="bo_table" value="<?= $bo_table ?>">
</div></div> <input type="hidden" name="sca" value="<?= $sca ?>">
<input type="hidden" name="sfl" value='wr_subject||wr_content'>
<hr class="line"> <input type="hidden" name="sop" value="and">
<ul>
<? <input type="text" name="stx" itemname="검색어" value="<?= $stx ?>">
$lists = array(); <?php ?><button type="submit" class="ui-btn">?</button>
for ($i=0; $i<count($list); $i++) { $lists[$i] = $list[$i]; } </form>
</div>
for ($ii=0; $ii < count($lists); $ii++) { </div>
$profile = get_member($lists[$ii]['mb_id']); <hr class="line">
include "$board_skin_path/inc.list_main.php"; <ul>
$lists[$ii]['datetime']=substr($lists[$ii]['wr_datetime'],0,4)."/".substr($lists[$ii]['wr_datetime'],5,2)."/".substr($lists[$ii]['wr_datetime'],8,2)." (".substr($lists[$ii]['wr_datetime'],11,8).")"; <?php
$lists = array();
$is_open = false; for ($i = 0; $i < count($list); $i++) {
$lists[$i] = $list[$i];
if(get_cookie('read_'.$lists[$ii]['wr_id']) == $lists[$ii]['wr_password']) { }
$is_open = true;
} for ($ii = 0; $ii < count($lists); $ii++) {
$lists[$ii]['content'] = conv_content($lists[$ii]['wr_content'], 0, 'wr_content'); $profile = get_member($lists[$ii]['mb_id']);
$lists[$ii]['content'] = search_font($stx, $lists[$ii]['content']); include "$board_skin_path/inc.list_main.php";
?> $lists[$ii]['datetime'] = substr($lists[$ii]['wr_datetime'], 0, 4) . "/" . substr($lists[$ii]['wr_datetime'], 5, 2) . "/" . substr($lists[$ii]['wr_datetime'], 8, 2) . " (" . substr($lists[$ii]['wr_datetime'], 11, 8) . ")";
<li>
<form name="fboardlist" method="post" action="<?=$board_skin_url?>/password.php" style="margin:0"> $is_open = false;
<input type="hidden" name="bo_table" value="<?=$bo_table?>">
<input type="hidden" name="sfl" value="<?=$sfl?>"> if (get_cookie('read_' . $lists[$ii]['wr_id']) == $lists[$ii]['wr_password']) {
<input type="hidden" name="stx" value="<?=$stx?>"> $is_open = true;
<input type="hidden" name="spt" value="<?=$spt?>"> }
<input type="hidden" name="page" value="<?=$page?>">
<input type="hidden" name="wr_idx" value="<?=$lists[$ii]['wr_id']?>"> $lists[$ii]['content'] = conv_content($lists[$ii]['wr_content'], 0, 'wr_content');
<input type="hidden" name="sw" value=""> $lists[$ii]['content'] = search_font($stx, $lists[$ii]['content']);
?>
<div class="memo-content content-area"> <li>
<em><?php if ($is_checkbox) { ?> <form name="fboardlist" method="post" action="<?= $board_skin_url ?>/password.php" style="margin:0">
<input type="checkbox" name="chk_id_<?php echo $lists[$ii]['wr_id'] ?>" value="<?php echo $lists[$ii]['wr_id'] ?>" class="chk_id"> <input type="hidden" name="bo_table" value="<?= $bo_table ?>">
<?php } ?> <input type="hidden" name="sfl" value="<?= $sfl ?>">
</em> <input type="hidden" name="stx" value="<?= $stx ?>">
<? if($lists[$ii]['is_notice']) { ?> <input type="hidden" name="spt" value="<?= $spt ?>">
<strong class="txt-point notice">!</strong> <input type="hidden" name="page" value="<?= $page ?>">
<? } else { ?> <input type="hidden" name="wr_idx" value="<?= $lists[$ii]['wr_id'] ?>">
<strong class="txt-point date"><?=date('Y/m/d',strtotime($lists[$ii]['wr_datetime']))?></strong> <input type="hidden" name="sw" value="">
<? } ?>
<? <div class="memo-content content-area">
if(strstr($lists[$ii]['wr_option'], 'secret') && !$is_admin && !$is_open) { <em><?php if ($is_checkbox) { ?>
?> <input type="checkbox" name="chk_id_<?php echo $lists[$ii]['wr_id'] ?>"
<a href="#" class="write_open secret ui-btn">***</a><p class="pass_in"><input type="password" name="wr_password" id="wr_password_<?=$ii?>" value="" placeholder="비밀번호"/> value="<?php echo $lists[$ii]['wr_id'] ?>" class="chk_id">
<button type="submit" class="ui-btn">입력</button></p> <?php } ?>
<? } else { </em>
if ($member['mb_level'] >= $board['bo_comment_level']) $is_comment_write = true; <?php if ($lists[$ii]['is_notice']) { ?>
if($board['bo_comment_write']<=$member['mb_level']) <strong class="txt-point notice">!</strong>
$is_comment_write=true;?> <?php } else { ?>
<? if(strstr($lists[$ii]['wr_option'], 'secret')) { <strong class="txt-point date"><?= date('Y/m/d', strtotime($lists[$ii]['wr_datetime'])) ?></strong>
?> <?php } ?>
&nbsp;<span class="txt-point">***</span>&nbsp;&nbsp; <?php
<? } ?> if (strstr($lists[$ii]['wr_option'], 'secret') && !$is_admin && !$is_open) {
<span class="con"> ?>
<?= $lists[$ii]['content'] ?> <a href="#" class="write_open secret ui-btn">***</a>
<? echo $secret_msg; ?> <p class="pass_in"><input type="password" name="wr_password" id="wr_password_<?= $ii ?>" value=""
</span> placeholder="비밀번호" />
<? } ?> <button type="submit" class="ui-btn">입력</button>
<p class="control"><? </p>
if($is_comment_write) { <?php } else {
?><a href="javascript:comment_wri('comment_write', '<?=$lists[$ii]['wr_id']?>');">+</a><? if ($member['mb_level'] >= $board['bo_comment_level'])
} if(($member['mb_id'] && ($member['mb_id'] == $lists[$ii]['mb_id'])) || $is_admin) { $is_comment_write = true;
if($update_href){?><a href="<?=$update_href?>">*</a><?} if ($board['bo_comment_write'] <= $member['mb_level'])
?><a href="<?=$delete_href?>">-</a><? $is_comment_write = true; ?>
} else if (!$lists[$ii]['mb_id']) { <?php if (strstr($lists[$ii]['wr_option'], 'secret')) {
?><a href="<?=$delete_href?>">-</a><? ?>
} &nbsp;<span class="txt-point">***</span>&nbsp;&nbsp;
?> </p> <?php } ?>
</div> <span class="con">
</form> <?= $lists[$ii]['content'] ?>
<? <?php echo $secret_msg; ?>
if(strstr($lists[$ii]['wr_option'], 'secret') && !$is_admin && !$is_open) { </span>
if($lists[$ii]['wr_comment']==1){?> <?php } ?>
<?}
} else { <p class="control">
$wr_id = $lists[$ii]['wr_id']; <?php
include($board_skin_path."/view_comment.php"); if ($is_comment_write) {
} ?><a href="javascript:comment_wri('comment_write', '<?= $lists[$ii]['wr_id'] ?>');">+</a>
?> <?php
<hr class="line"> }
</li> if (($member['mb_id'] && ($member['mb_id'] == $lists[$ii]['mb_id'])) || $is_admin) {
<? } if ($update_href) { ?><a href="<?= $update_href ?>">*</a>
?> <?php }
<? if (count($lists) == 0) { echo "<li class='no-data'>내역이 없습니다.</li>"; } ?> ?><a href="<?= $delete_href ?>">-</a>
</ul> <?php
<?php if ($is_checkbox) { ?> } else if (!$lists[$ii]['mb_id']) {
<hr class="line"> ?><a href="<?= $delete_href ?>">-</a>
<div class="bo_fx txt-right"> <?php
}
<form name="fchecklist" id="fchecklist" action="./board_list_update.php" method="post"> ?>
<input type="hidden" name="write_table" value="<?=$write_table?>"> </p>
<input type="hidden" name="bo_table" value="<?php echo $bo_table ?>"> </div>
<input type="hidden" name="sfl" value="<?php echo $sfl ?>"> </form>
<input type="hidden" name="stx" value="<?php echo $stx ?>"> <?php
<input type="hidden" name="spt" value="<?php echo $spt ?>"> if (strstr($lists[$ii]['wr_option'], 'secret') && !$is_admin && !$is_open) {
<input type="hidden" name="sst" value="<?php echo $sst ?>"> if ($lists[$ii]['wr_comment'] == 1) { ?>
<input type="hidden" name="sod" value="<?php echo $sod ?>"> <?php }
<input type="hidden" name="page" value="<?php echo $page ?>"> } else {
<input type="hidden" name="sw" value=""> $wr_id = $lists[$ii]['wr_id'];
<input type="hidden" name="btn_submit" value=""> include $board_skin_path . "/view_comment.php";
</form> }
?>
<?if($is_checkbox && count($lists)>0){?> <hr class="line">
<span class="chkall"><input type="checkbox" id="chkall" onclick="if (this.checked) all_checked(true); else all_checked(false);"> </li>
</span> <?php }
<?}?> ?>
<input type="submit" name="btn_submit" value="선택삭제" onclick="select_delete();" class="ui-btn small admin"> <?php if (count($lists) == 0) {
<input type="submit" name="btn_submit" value="선택복사" onclick="select_copy('copy');" class="ui-btn small admin"> echo "<li class='no-data'>내역이 없습니다.</li>";
<input type="submit" name="btn_submit" value="선택이동" onclick="select_copy('move');" class="ui-btn small admin"> } ?>
</div> </ul>
<?php } ?> <?php if ($is_checkbox) { ?>
</div> <hr class="line">
<!-- 페이지 --> <div class="bo_fx txt-right">
<? echo $write_pages; ?>
</div> <form name="fchecklist" id="fchecklist" action="./board_list_update.php" method="post">
<input type="hidden" name="write_table" value="<?= $write_table ?>">
<script language="JavaScript"> <input type="hidden" name="bo_table" value="<?php echo $bo_table ?>">
//if ("<?=$sca?>") document.fcategory.sca.value = "<?=$sca?>"; <input type="hidden" name="sfl" value="<?php echo $sfl ?>">
if ("<?=$stx?>") { <input type="hidden" name="stx" value="<?php echo $stx ?>">
document.fsearch.sfl.value = "<?=$sfl?>"; <input type="hidden" name="spt" value="<?php echo $spt ?>">
document.fsearch.sop.value = "<?=$sop?>"; <input type="hidden" name="sst" value="<?php echo $sst ?>">
} <input type="hidden" name="sod" value="<?php echo $sod ?>">
<input type="hidden" name="page" value="<?php echo $page ?>">
$(".write_open").click(function(){ <input type="hidden" name="sw" value="">
$(this).next().toggleClass("on"); <input type="hidden" name="btn_submit" value="">
}); </form>
function comment_box(co_id, wr_id) { <?php if ($is_checkbox && count($lists) > 0) { ?>
$('.modify_area').hide(); <span class="chkall"><input type="checkbox" id="chkall"
$('.comment-content').show(); onclick="if (this.checked) all_checked(true); else all_checked(false);">
</span>
$('#c_'+co_id).find('.modify_area').show(); <?php } ?>
$('#c_'+co_id).find('.comment-content').hide(); <input type="submit" name="btn_submit" value="선택삭제" onclick="select_delete();" class="ui-btn small admin">
<input type="submit" name="btn_submit" value="선택복사" onclick="select_copy('copy');"
$('#save_co_comment_'+co_id).focus(); class="ui-btn small admin">
<input type="submit" name="btn_submit" value="선택이동" onclick="select_copy('move');"
var modify_form = document.getElementById('frm_modify_comment'); class="ui-btn small admin">
modify_form.wr_id.value = wr_id; </div>
modify_form.comment_id.value = co_id; <?php } ?>
} </div>
<!-- 페이지 -->
function mod_comment(co_id) { <?php echo $write_pages; ?>
var modify_form = document.getElementById('frm_modify_comment'); </div>
var wr_content = $('#save_co_comment_'+co_id).val();
var wr_option = ''; <script language="JavaScript">
modify_form.wr_content.value = wr_content; //if ("<?= $sca ?>") document.fcategory.sca.value = "<?= $sca ?>";
modify_form.wr_option.value = wr_option; if ("<?= $stx ?>") {
modify_form.wr_id.value=co_id; document.fsearch.sfl.value = "<?= $sfl ?>";
modify_form.comment_id.value=co_id; document.fsearch.sop.value = "<?= $sop ?>";
$('#frm_modify_comment').submit(); }
}
</script> $(".write_open").click(function () {
$(this).next().toggleClass("on");
<? if ($is_checkbox) { ?> });
<script>
function comment_box(co_id, wr_id) {
var count=0; $('.modify_area').hide();
$('.chk_id').change(function(){ $('.comment-content').show();
if($(this).prop('checked')){
$("#fchecklist").append('<input type="checkbox" id="ck_id_'+$(this).val()+'" name="chk_wr_id[]" class="chkd" value="'+$(this).val()+'" checked style="display:none;">'); $('#c_' + co_id).find('.modify_area').show();
count++; $('#c_' + co_id).find('.comment-content').hide();
}
if($(this).prop('checked')==false){ $('#save_co_comment_' + co_id).focus();
$('#ck_id_'+$(this).val()).remove();
count--; var modify_form = document.getElementById('frm_modify_comment');
} modify_form.wr_id.value = wr_id;
}); modify_form.comment_id.value = co_id;
}
function all_checked(sw) { function mod_comment(co_id) {
var clen=$('.chk_id').length; var modify_form = document.getElementById('frm_modify_comment');
$('.chk_id').prop('checked',sw); var wr_content = $('#save_co_comment_' + co_id).val();
if(sw==true){ var wr_option = '';
for(i=0;i<clen;i++){ modify_form.wr_content.value = wr_content;
$("#fchecklist").append('<input type="checkbox" id="ck_id_'+$('.chk_id').eq(i).val()+'" class="chkd" name="chk_wr_id[]" value="'+$('.chk_id').eq(i).val()+'" checked style="display:none;">'); modify_form.wr_option.value = wr_option;
count++; modify_form.wr_id.value = co_id;
} modify_form.comment_id.value = co_id;
$('#frm_modify_comment').submit();
}else{ }
$('.chkd').remove(); </script>
count--;
} <?php if ($is_checkbox) { ?>
} <script>
var count = 0;
function check_confirm(str) $('.chk_id').change(function () {
{ if ($(this).prop('checked')) {
var f = $('.chkd'); $("#fchecklist").append('<input type="checkbox" id="ck_id_' + $(this).val() + '" name="chk_wr_id[]" class="chkd" value="' + $(this).val() + '" checked style="display:none;">');
var chk_count = 0; count++;
}
for (var i=0; i<f.length; i++) { if ($(this).prop('checked') == false) {
if (f.prop("checked")){ $('#ck_id_' + $(this).val()).remove();
chk_count++; count--;
} }
} });
if (!chk_count) {
alert(str + "할 게시물을 하나 이상 선택하세요."); function all_checked(sw) {
return false; var clen = $('.chk_id').length;
} $('.chk_id').prop('checked', sw);
return true; if (sw == true) {
} for (i = 0; i < clen; i++) {
$("#fchecklist").append('<input type="checkbox" id="ck_id_' + $('.chk_id').eq(i).val() + '" class="chkd" name="chk_wr_id[]" value="' + $('.chk_id').eq(i).val() + '" checked style="display:none;">');
// 선택한 게시물 삭제 count++;
function select_delete() }
{
var f = document.fchecklist; } else {
$('.chkd').remove();
str = "삭제"; count--;
if (!check_confirm(str)) }
return; }
if (!confirm("선택한 게시물을 정말 "+str+" 하시겠습니까?\n\n한번 "+str+"한 자료는 복구할 수 없습니다"))
return; function check_confirm(str) {
f.btn_submit.value="선택삭제"; var f = $('.chkd');
f.removeAttribute("target"); var chk_count = 0;
f.action = "./board_list_update.php";
f.submit(); for (var i = 0; i < f.length; i++) {
} if (f.prop("checked")) {
chk_count++;
// 선택한 게시물 복사 및 이동 }
function select_copy(sw) }
{
var f = document.fchecklist; if (!chk_count) {
alert(str + "할 게시물을 하나 이상 선택하세요.");
if (sw == "copy") return false;
str = "복사"; }
else return true;
str = "이동"; }
if (!check_confirm(str)) // 선택한 게시물 삭제
return; function select_delete() {
var f = document.fchecklist;
var sub_win = window.open("", "move", "left=50, top=50, width=500, height=550, scrollbars=1");
str = "삭제";
f.sw.value = sw; if (!check_confirm(str))
f.btn_submit.vaule="선택"+str; return;
f.target = "move";
f.action = "./move.php"; if (!confirm("선택한 게시물을 정말 " + str + " 하시겠습니까?\n\n한번 " + str + "한 자료는 복구할 수 없습니다"))
f.submit(); return;
} f.btn_submit.value = "선택삭제";
</script> f.removeAttribute("target");
<? } ?> f.action = "./board_list_update.php";
<form name="modify_comment" id="frm_modify_comment" action="./write_comment_update.php" method="post" autocomplete="off"> f.submit();
<input type="hidden" name="w" value="cu"> }
<input type="hidden" name="bo_table" value="<?php echo $bo_table ?>">
<input type="hidden" name="sca" value="<?php echo $sca ?>"> // 선택한 게시물 복사 및 이동
<input type="hidden" name="sfl" value="<?php echo $sfl ?>"> function select_copy(sw) {
<input type="hidden" name="stx" value="<?php echo $stx ?>"> var f = document.fchecklist;
<input type="hidden" name="spt" value="<?php echo $spt ?>">
<input type="hidden" name="page" value="<?php echo $page ?>"> if (sw == "copy")
str = "복사";
<input type="hidden" name="comment_id" value=""> else
<input type="hidden" name="wr_id" value=""> str = "이동";
<input type="hidden" name="wr_option" value="" >
<textarea name="wr_content" style="display: none;"></textarea> if (!check_confirm(str))
<button type="submit" style="display: none;"></button> return;
</form>
var sub_win = window.open("", "move", "left=50, top=50, width=500, height=550, scrollbars=1");
f.sw.value = sw;
f.btn_submit.vaule = "선택" + str;
f.target = "move";
f.action = "./move.php";
f.submit();
}
</script>
<?php } ?>
<form name="modify_comment" id="frm_modify_comment" action="./write_comment_update.php" method="post"
autocomplete="off">
<input type="hidden" name="w" value="cu">
<input type="hidden" name="bo_table" value="<?php echo $bo_table ?>">
<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="comment_id" value="">
<input type="hidden" name="wr_id" value="">
<input type="hidden" name="wr_option" value="">
<textarea name="wr_content" style="display: none;"></textarea>
<button type="submit" style="display: none;"></button>
</form>

View file

@ -1,10 +1,8 @@
<?php <?php
include_once('./_common.php'); include_once './_common.php';
if($_POST['wr_password']){ if ($_POST['wr_password']) {
set_cookie('read_'.$_POST['wr_idx'], sql_password($_POST['wr_password']), 3600); set_cookie('read_' . $_POST['wr_idx'], sql_password($_POST['wr_password']), 3600);
} }
goto_url(G5_HTTP_BBS_URL.'/board.php?bo_table='.$bo_table.'&amp;wr_id='.$wr_id.$qstr); goto_url(G5_HTTP_BBS_URL . '/board.php?bo_table=' . $bo_table . '&amp;wr_id=' . $wr_id . $qstr);
?>

View file

@ -1,7 +1,7 @@
<? <?php
if (!defined("_GNUBOARD_")) exit; // 개별 페이지 접근 불가 if (!defined("_GNUBOARD_"))
exit;
set_session("ss_delete_token", $token = uniqid(time()));
set_session("ss_delete_token", $token = uniqid(time()));
goto_url("./board.php?bo_table=$bo_table" . $qstr);
?> goto_url("./board.php?bo_table=$bo_table" . $qstr);

View file

@ -1,110 +1,99 @@
<?php <?php
if (!defined('_GNUBOARD_')) exit; // 개별 페이지 접근 불가 if (!defined('_GNUBOARD_'))
exit;
$list = array();
$list = array();
// 코멘트 출력
$sql = " select * from {$write_table} where wr_parent = '{$wr_id}' and wr_is_comment = 1 order by wr_comment, wr_comment_reply "; // 코멘트 출력
$result = sql_query($sql); $sql = " select * from {$write_table} where wr_parent = '{$wr_id}' and wr_is_comment = 1 order by wr_comment, wr_comment_reply ";
for ($i=0; $c_row=sql_fetch_array($result); $i++) $result = sql_query($sql);
{ for ($i = 0; $c_row = sql_fetch_array($result); $i++) {
$list[$i] = $c_row; $list[$i] = $c_row;
//$list[$i]['name'] = get_sideview($c_row['mb_id'], cut_str($c_row['wr_name'], 20, ''), $c_row['wr_email'], $c_row['wr_homepage']); //$list[$i]['name'] = get_sideview($c_row['mb_id'], cut_str($c_row['wr_name'], 20, ''), $c_row['wr_email'], $c_row['wr_homepage']);
$tmp_name = get_text(cut_str($c_row['wr_name'], $config['cf_cut_name'])); // 설정된 자리수 만큼만 이름 출력 $tmp_name = get_text(cut_str($c_row['wr_name'], $config['cf_cut_name'])); // 설정된 자리수 만큼만 이름 출력
if ($board['bo_use_sideview']) if ($board['bo_use_sideview'])
$list[$i]['name'] = get_sideview($c_row['mb_id'], $tmp_name, $c_row['wr_email'], $c_row['wr_homepage']); $list[$i]['name'] = get_sideview($c_row['mb_id'], $tmp_name, $c_row['wr_email'], $c_row['wr_homepage']);
else else
$list[$i]['name'] = '<span class="'.($c_row['mb_id']?'member':'guest').'">'.$tmp_name.'</span>'; $list[$i]['name'] = '<span class="' . ($c_row['mb_id'] ? 'member' : 'guest') . '">' . $tmp_name . '</span>';
// 공백없이 연속 입력한 문자 자르기 (way 보드 참고. way.co.kr) // 공백없이 연속 입력한 문자 자르기 (way 보드 참고. way.co.kr)
//$list[$i]['content'] = eregi_replace("[^ \n<>]{130}", "\\0\n", $c_row['wr_content']); //$list[$i]['content'] = eregi_replace("[^ \n<>]{130}", "\\0\n", $c_row['wr_content']);
$list[$i]['content'] = $list[$i]['content1']= '비밀글 입니다.'; $list[$i]['content'] = $list[$i]['content1'] = '비밀글 입니다.';
if (!strstr($c_row['wr_option'], 'secret') || if (
$is_admin || !strstr($c_row['wr_option'], 'secret') ||
($write['mb_id']==$member['mb_id'] && $member['mb_id']) || $is_admin ||
($c_row['mb_id']==$member['mb_id'] && $member['mb_id'])) { ($write['mb_id'] == $member['mb_id'] && $member['mb_id']) ||
$list[$i]['content1'] = $c_row['wr_content']; ($c_row['mb_id'] == $member['mb_id'] && $member['mb_id'])
$list[$i]['content'] = conv_content($c_row['wr_content'], 0, 'wr_content'); ) {
$list[$i]['content'] = search_font($stx, $list[$i]['content']); $list[$i]['content1'] = $c_row['wr_content'];
} else { $list[$i]['content'] = conv_content($c_row['wr_content'], 0, 'wr_content');
$ss_name = 'ss_secret_comment_'.$bo_table.'_'.$list[$i]['wr_id']; $list[$i]['content'] = search_font($stx, $list[$i]['content']);
} else {
if(!get_session($ss_name)) $ss_name = 'ss_secret_comment_' . $bo_table . '_' . $list[$i]['wr_id'];
$list[$i]['content'] = '<a href="./password.php?w=sc&amp;bo_table='.$bo_table.'&amp;wr_id='.$list[$i]['wr_id'].$qstr.'" class="s_cmt">댓글내용 확인</a>';
else { if (!get_session($ss_name))
$list[$i]['content'] = conv_content($c_row['wr_content'], 0, 'wr_content'); $list[$i]['content'] = '<a href="./password.php?w=sc&amp;bo_table=' . $bo_table . '&amp;wr_id=' . $list[$i]['wr_id'] . $qstr . '" class="s_cmt">댓글내용 확인</a>';
$list[$i]['content'] = search_font($stx, $list[$i]['content']); else {
} $list[$i]['content'] = conv_content($c_row['wr_content'], 0, 'wr_content');
} $list[$i]['content'] = search_font($stx, $list[$i]['content']);
}
$list[$i]['datetime'] = substr($c_row['wr_datetime'],2,14); }
// 관리자가 아니라면 중간 IP 주소를 감춘후 보여줍니다. $list[$i]['datetime'] = substr($c_row['wr_datetime'], 2, 14);
$list[$i]['ip'] = $c_row['wr_ip'];
if (!$is_admin) // 관리자가 아니라면 중간 IP 주소를 감춘후 보여줍니다.
$list[$i]['ip'] = preg_replace("/([0-9]+).([0-9]+).([0-9]+).([0-9]+)/", G5_IP_DISPLAY, $c_row['wr_ip']); $list[$i]['ip'] = $c_row['wr_ip'];
if (!$is_admin)
$list[$i]['is_reply'] = false; $list[$i]['ip'] = preg_replace("/([0-9]+).([0-9]+).([0-9]+).([0-9]+)/", G5_IP_DISPLAY, $c_row['wr_ip']);
$list[$i]['is_edit'] = false;
$list[$i]['is_del'] = false; $list[$i]['is_reply'] = false;
if ($is_comment_write || $is_admin) $list[$i]['is_edit'] = false;
{ $list[$i]['is_del'] = false;
$token = ''; if ($is_comment_write || $is_admin) {
$token = '';
if ($member['mb_id'])
{ if ($member['mb_id']) {
if ($c_row['mb_id'] == $member['mb_id'] || $is_admin) if ($c_row['mb_id'] == $member['mb_id'] || $is_admin) {
{ set_session('ss_delete_comment_' . $c_row['wr_id'] . '_token', $token = uniqid(time()));
set_session('ss_delete_comment_'.$c_row['wr_id'].'_token', $token = uniqid(time())); $list[$i]['del_link'] = './delete_comment.php?bo_table=' . $bo_table . '&amp;comment_id=' . $c_row['wr_id'] . '&amp;token=' . $token . '&amp;page=' . $page . $qstr;
$list[$i]['del_link'] = './delete_comment.php?bo_table='.$bo_table.'&amp;comment_id='.$c_row['wr_id'].'&amp;token='.$token.'&amp;page='.$page.$qstr; $list[$i]['is_edit'] = true;
$list[$i]['is_edit'] = true; $list[$i]['is_del'] = true;
$list[$i]['is_del'] = true; }
} } else {
} if (!$c_row['mb_id']) {
else $list[$i]['del_link'] = './password.php?w=x&amp;bo_table=' . $bo_table . '&amp;comment_id=' . $c_row['wr_id'] . '&amp;page=' . $page . $qstr;
{ $list[$i]['is_del'] = true;
if (!$c_row['mb_id']) { }
$list[$i]['del_link'] = './password.php?w=x&amp;bo_table='.$bo_table.'&amp;comment_id='.$c_row['wr_id'].'&amp;page='.$page.$qstr; }
$list[$i]['is_del'] = true;
} if (strlen($c_row['wr_comment_reply']) < 5)
} $list[$i]['is_reply'] = true;
}
if (strlen($c_row['wr_comment_reply']) < 5)
$list[$i]['is_reply'] = true; // 05.05.22
} // 답변있는 코멘트는 수정, 삭제 불가
if ($i > 0 && !$is_admin) {
// 05.05.22 if ($c_row['wr_comment_reply']) {
// 답변있는 코멘트는 수정, 삭제 불가 $tmp_comment_reply = substr($c_row['wr_comment_reply'], 0, strlen($c_row['wr_comment_reply']) - 1);
if ($i > 0 && !$is_admin) if ($tmp_comment_reply == $list[$i - 1]['wr_comment_reply']) {
{ $list[$i - 1]['is_edit'] = false;
if ($c_row['wr_comment_reply']) $list[$i - 1]['is_del'] = false;
{ }
$tmp_comment_reply = substr($c_row['wr_comment_reply'], 0, strlen($c_row['wr_comment_reply']) - 1); }
if ($tmp_comment_reply == $list[$i-1]['wr_comment_reply']) }
{ }
$list[$i-1]['is_edit'] = false;
$list[$i-1]['is_del'] = false; // 코멘트수 제한 설정값
} if ($is_admin) {
} $comment_min = $comment_max = 0;
} } else {
} $comment_min = (int) $board['bo_comment_min'];
$comment_max = (int) $board['bo_comment_max'];
// 코멘트수 제한 설정값 }
if ($is_admin)
{ include $board_skin_path . '/view_comment.skin.php';
$comment_min = $comment_max = 0;
}
else
{
$comment_min = (int)$board['bo_comment_min'];
$comment_max = (int)$board['bo_comment_max'];
}
include($board_skin_path.'/view_comment.skin.php');
?>

View file

@ -1,101 +1,115 @@
<? <?php
if (!defined("_GNUBOARD_")) exit; // 개별 페이지 접근 불가 if (!defined("_GNUBOARD_"))
?> exit;
?>
<script language="JavaScript">
// 글자수 제한 <script language="JavaScript">
var char_min = parseInt(<?=$comment_min?>); // 최소 // 글자수 제한
var char_max = parseInt(<?=$comment_max?>); // 최대 var char_min = parseInt(<?= $comment_min ?>); // 최소
</script> var char_max = parseInt(<?= $comment_max ?>); // 최대
</script>
<!-- 코멘트 쓰기 -->
<!-- 코멘트 쓰기 -->
<? if ($is_comment_write) {
if($w == '') $w = 'c'; <?php if ($is_comment_write) {
?> if ($w == '')
<div class="ui-write-area" id="comment_write<?=$lists[$ii]['wr_id']?>" style="display:none;"> $w = 'c';
<!-- 코멘트 입력테이블시작 --> ?>
<form name="fviewcomment" action="<?=G5_BBS_URL?>/write_comment_update.php" method="post" enctype="multipart/form-data" autocomplete="off"> <div class="ui-write-area" id="comment_write<?= $lists[$ii]['wr_id'] ?>" style="display:none;">
<input type="hidden" name="w" value="<?php echo $w ?>"> <!-- 코멘트 입력테이블시작 -->
<input type="hidden" name="bo_table" value="<?php echo $bo_table ?>"> <form name="fviewcomment" action="<?= G5_BBS_URL ?>/write_comment_update.php" method="post"
<input type="hidden" name="wr_id" value="<?php echo $lists[$ii]['wr_id'] ?>"> enctype="multipart/form-data" autocomplete="off">
<input type="hidden" name="sca" value="<?php echo $sca ?>"> <input type="hidden" name="w" value="<?php echo $w ?>">
<input type="hidden" name="sfl" value="<?php echo $sfl ?>"> <input type="hidden" name="bo_table" value="<?php echo $bo_table ?>">
<input type="hidden" name="stx" value="<?php echo $stx ?>"> <input type="hidden" name="wr_id" value="<?php echo $lists[$ii]['wr_id'] ?>">
<input type="hidden" name="spt" value="<?php echo $spt ?>"> <input type="hidden" name="sca" value="<?php echo $sca ?>">
<input type="hidden" name="page" value="<?php echo $page ?>"> <input type="hidden" name="sfl" value="<?php echo $sfl ?>">
<input type="hidden" name="stx" value="<?php echo $stx ?>">
<p class="ui-text-area"> <input type="hidden" name="spt" value="<?php echo $spt ?>">
<input type="text" name="wr_content" required class="frm-input full" value="<?=$list[$i]['wr_content']?>"> <input type="hidden" name="page" value="<?php echo $page ?>">
<button type="submit" class="ui-btn" accesskey='s'>입력</button>
</p> <p class="ui-text-area">
<?if(!$is_member && $is_comment_write){?> <input type="text" name="wr_content" required class="frm-input full" value="<?= $list[$i]['wr_content'] ?>">
<p> <button type="submit" class="ui-btn" accesskey='s'>입력</button>
<input type="text" name="wr_name" placeholder="이름" value="<?=$_COOKIE['MMB_NAME']?>" style="max-width:40%" /> </p>
<input type="password" name="wr_password" value="<?=$_COOKIE['MMB_PW']?>" placeholder="비밀번호" style="max-width:40%" /> <?php if (!$is_member && $is_comment_write) { ?>
</p> <p>
<?}?> <input type="text" name="wr_name" placeholder="이름" value="<?= $_COOKIE['MMB_NAME'] ?>"
</form> style="max-width:40%" />
</div> <input type="password" name="wr_password" value="<?= $_COOKIE['MMB_PW'] ?>" placeholder="비밀번호"
<? } ?> style="max-width:40%" />
<ul> </p>
<!-- 코멘트 리스트 --> <?php } ?>
<? </form>
for ($i=0; $i<count($list); $i++) { </div>
$comment_id = $list[$i]['wr_id']; <?php } ?>
?> <ul>
<li id="c_<?=$comment_id?>"> <!-- 코멘트 리스트 -->
<a name="c_<?=$comment_id?>"></a> <?php
<div class="comment-content content-area"> for ($i = 0; $i < count($list); $i++) {
<em></em> $comment_id = $list[$i]['wr_id'];
<span class="date"><?=date("Y/m/d",strtotime($list[$i]['wr_datetime']))?></span> ?>
<!-- 코멘트 출력 --> <li id="c_<?= $comment_id ?>">
<? <a name="c_<?= $comment_id ?>"></a>
if (strstr($list[$i]['wr_option'], "secret")) echo "<span style='color:#ff6600;'>*</span> "; <div class="comment-content content-area">
$str = $list[$i]['content']; <em></em>
if (strstr($list[$i]['wr_option'], "secret")) <span class="date"><?= date("Y/m/d", strtotime($list[$i]['wr_datetime'])) ?></span>
$str = "<span style='color:#ff6600;'>$str</span>"; <!-- 코멘트 출력 -->
<?php
$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); if (strstr($list[$i]['wr_option'], "secret"))
$str = preg_replace("/\[\<a\s.*href\=\"(http|https|ftp)\:\/\/([^[:space:]]+)\.(swf)\".*\<\/a\>\]/i", "<script>doc_write(flash_movie('$1://$2.$3'));</script>", $str); echo "<span style='color:#ff6600;'>*</span> ";
$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); $str = $list[$i]['content'];
echo "<span class='con'>".$str."</span>"; if (strstr($list[$i]['wr_option'], "secret"))
$query_string = clean_query_string($_SERVER['QUERY_STRING']); $str = "<span 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);
if($w == 'cu') { $str = preg_replace("/\[\<a\s.*href\=\"(http|https|ftp)\:\/\/([^[:space:]]+)\.(swf)\".*\<\/a\>\]/i", "<script>doc_write(flash_movie('$1://$2.$3'));</script>", $str);
$sql = " select wr_id, wr_content, mb_id from $write_table where wr_id = '$comment_id' and wr_is_comment = '1' "; $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);
$cmt = sql_fetch($sql); echo "<span class='con'>" . $str . "</span>";
if (!($is_admin || ($member['mb_id'] == $cmt['mb_id'] && $cmt['mb_id']))) $query_string = clean_query_string($_SERVER['QUERY_STRING']);
$cmt['wr_content'] = '';
$c_wr_content = $cmt['wr_content'];
} if ($w == 'cu') {
$sql = " select wr_id, wr_content, mb_id from $write_table where wr_id = '$comment_id' and wr_is_comment = '1' ";
$c_edit_href = './board.php?'.$query_string.'&amp;comment_id='.$comment_id.'&amp;wr_id='.$wr_id.'w=cu'; $cmt = sql_fetch($sql);
if (!($is_admin || ($member['mb_id'] == $cmt['mb_id'] && $cmt['mb_id'])))
?> $cmt['wr_content'] = '';
<? if ($list[$i]['is_edit']||$list[$i]['is_del']) { ?> $c_wr_content = $cmt['wr_content'];
<p class="control"><? }
if ($list[$i]['is_edit']) { ?><a href="javascript:comment_box('<? echo $comment_id ?>', '<?=$list[$ii]['wr_id']?>');" >*</a><? }
if ($list[$i]['is_del']) { echo "<a href=\"javascript:comment_delete('{$list[$i]['del_link']}');\">-</a>"; } $c_edit_href = './board.php?' . $query_string . '&amp;comment_id=' . $comment_id . '&amp;wr_id=' . $wr_id . 'w=cu';
?></p>
<?}?> ?>
<span id="edit_<? echo $comment_id ?>"></span><!-- 수정 --> <?php if ($list[$i]['is_edit'] || $list[$i]['is_del']) { ?>
<p class="control">
<input type="hidden" value="<? echo strstr($list[$i]['wr_option'],"secret") ?>" id="secret_comment_<? echo $comment_id ?>"> <?php
<input type="text" id="save_comment_<? echo $comment_id ?>" style="display:none" value="<? echo get_text($list[$i]['content1'], 0) ?>"> if ($list[$i]['is_edit']) { ?><a
</div> href="javascript:comment_box('<?php echo $comment_id ?>', '<?= $list[$ii]['wr_id'] ?>');">*</a>
<?php }
<? if ($list[$i]['is_edit']) { ?> if ($list[$i]['is_del']) {
<div class="modify_area ui-text-area" id="save_comment_<?php echo $comment_id ?>" style="display:none;"> echo "<a href=\"javascript:comment_delete('{$list[$i]['del_link']}');\">-</a>";
<input type="text" id="save_co_comment_<?php echo $comment_id ?>" value="<?php echo get_text($list[$i]['wr_content'], 0) ?>" class="full"> }
<p class="txt-right"><button type="button" class="mod_comment ui-btn" onclick="mod_comment('<?php echo $comment_id ?>')">수정</button></p> ?>
</div> </p>
<? } ?> <?php } ?>
</li> <span id="edit_<?php echo $comment_id ?>"></span><!-- 수정 -->
<? } ?>
</ul> <input type="hidden" value="<?php echo strstr($list[$i]['wr_option'], "secret") ?>"
id="secret_comment_<?php echo $comment_id ?>">
<? <input type="text" id="save_comment_<?php echo $comment_id ?>" style="display:none"
include_once("$board_skin_path/view_skin_js.php"); value="<?php echo get_text($list[$i]['content1'], 0) ?>">
?> </div>
<?php if ($list[$i]['is_edit']) { ?>
<div class="modify_area ui-text-area" id="save_comment_<?php echo $comment_id ?>" style="display:none;">
<input type="text" id="save_co_comment_<?php echo $comment_id ?>"
value="<?php echo get_text($list[$i]['wr_content'], 0) ?>" class="full">
<p class="txt-right"><button type="button" class="mod_comment ui-btn"
onclick="mod_comment('<?php echo $comment_id ?>')">수정</button></p>
</div>
<?php } ?> </li>
<?php } ?>
</ul>
<?php
include_once "$board_skin_path/view_skin_js.php";

View file

@ -1,13 +1,12 @@
<script language='JavaScript'> <script language='JavaScript'>
function comment_wri(name, id) { function comment_wri(name, id) {
$('.modify_area').hide(); $('.modify_area').hide();
$('.qna-comment-content').show(); $('.qna-comment-content').show();
var layer = document.getElementById(name+id); var layer = document.getElementById(name + id);
layer.style.display = (layer.style.display == "none")? "block" : "none"; layer.style.display = (layer.style.display == "none") ? "block" : "none";
} }
function comment_delete(url) function comment_delete(url) {
{ if (confirm("이 코멘트를 삭제하시겠습니까?")) location.href = url;
if (confirm("이 코멘트를 삭제하시겠습니까?")) location.href = url; }
} </script>
</script>

823
write.php
View file

@ -1,413 +1,410 @@
<?php <?php
include_once('./_common.php'); include_once './_common.php';
include_once(G5_EDITOR_LIB); include_once G5_EDITOR_LIB;
if (!$board['bo_table']) { if (!$board['bo_table']) {
alert('존재하지 않는 게시판입니다.', G5_URL); alert('존재하지 않는 게시판입니다.', G5_URL);
} }
if (!$bo_table) { if (!$bo_table) {
alert("bo_table 값이 넘어오지 않았습니다.\\nwrite.php?bo_table=code 와 같은 방식으로 넘겨 주세요.", G5_URL); alert("bo_table 값이 넘어오지 않았습니다.\\nwrite.php?bo_table=code 와 같은 방식으로 넘겨 주세요.", G5_URL);
} }
check_device($board['bo_device']); check_device($board['bo_device']);
$notice_array = explode(',', trim($board['bo_notice'])); $notice_array = explode(',', trim($board['bo_notice']));
if (!($w == '' || $w == 'u' || $w == 'r')) { if (!($w == '' || $w == 'u' || $w == 'r')) {
alert('w 값이 제대로 넘어오지 않았습니다.'); alert('w 값이 제대로 넘어오지 않았습니다.');
} }
if ($w == 'u' || $w == 'r') { if ($w == 'u' || $w == 'r') {
if ($write['wr_id']) { if ($write['wr_id']) {
// 가변 변수로 $wr_1 .. $wr_10 까지 만든다. // 가변 변수로 $wr_1 .. $wr_10 까지 만든다.
for ($i=1; $i<=10; $i++) { for ($i = 1; $i <= 10; $i++) {
$vvar = "wr_".$i; $vvar = "wr_" . $i;
$$vvar = $write['wr_'.$i]; $$vvar = $write['wr_' . $i];
} }
} else { } else {
alert("글이 존재하지 않습니다.\\n삭제되었거나 이동된 경우입니다.", G5_URL); alert("글이 존재하지 않습니다.\\n삭제되었거나 이동된 경우입니다.", G5_URL);
} }
} }
if ($w == '') { if ($w == '') {
if ($wr_id) { if ($wr_id) {
alert('글쓰기에는 \$wr_id 값을 사용하지 않습니다.', G5_BBS_URL.'/board.php?bo_table='.$bo_table); alert('글쓰기에는 \$wr_id 값을 사용하지 않습니다.', G5_BBS_URL . '/board.php?bo_table=' . $bo_table);
} }
if ($member['mb_level'] < $board['bo_write_level']) { if ($member['mb_level'] < $board['bo_write_level']) {
if ($member['mb_id']) { if ($member['mb_id']) {
alert('글을 쓸 권한이 없습니다.'); alert('글을 쓸 권한이 없습니다.');
} else { } else {
alert("글을 쓸 권한이 없습니다.\\n회원이시라면 로그인 후 이용해 보십시오.", './login.php?'.$qstr.'&amp;url='.urlencode($_SERVER['SCRIPT_NAME'].'?bo_table='.$bo_table)); alert("글을 쓸 권한이 없습니다.\\n회원이시라면 로그인 후 이용해 보십시오.", './login.php?' . $qstr . '&amp;url=' . urlencode($_SERVER['SCRIPT_NAME'] . '?bo_table=' . $bo_table));
} }
} }
// 음수도 true 인것을 왜 이제야 알았을까? // 음수도 true 인것을 왜 이제야 알았을까?
if ($is_member) { if ($is_member) {
$tmp_point = ($member['mb_point'] > 0) ? $member['mb_point'] : 0; $tmp_point = ($member['mb_point'] > 0) ? $member['mb_point'] : 0;
if ($tmp_point + $board['bo_write_point'] < 0 && !$is_admin) { if ($tmp_point + $board['bo_write_point'] < 0 && !$is_admin) {
alert('보유하신 포인트('.number_format($member['mb_point']).')가 없거나 모자라서 글쓰기('.number_format($board['bo_write_point']).')가 불가합니다.\\n\\n포인트를 적립하신 후 다시 글쓰기 해 주십시오.'); alert('보유하신 포인트(' . number_format($member['mb_point']) . ')가 없거나 모자라서 글쓰기(' . number_format($board['bo_write_point']) . ')가 불가합니다.\\n\\n포인트를 적립하신 후 다시 글쓰기 해 주십시오.');
} }
} }
$title_msg = '글쓰기'; $title_msg = '글쓰기';
} else if ($w == 'u') { } else if ($w == 'u') {
// 김선용 1.00 : 글쓰기 권한과 수정은 별도로 처리되어야 함 // 김선용 1.00 : 글쓰기 권한과 수정은 별도로 처리되어야 함
//if ($member['mb_level'] < $board['bo_write_level']) { //if ($member['mb_level'] < $board['bo_write_level']) {
if($member['mb_id'] && $write['mb_id'] == $member['mb_id']) { if ($member['mb_id'] && $write['mb_id'] == $member['mb_id']) {
; ;
} else if ($member['mb_level'] < $board['bo_write_level']) { } else if ($member['mb_level'] < $board['bo_write_level']) {
if ($member['mb_id']) { if ($member['mb_id']) {
alert('글을 수정할 권한이 없습니다.'); alert('글을 수정할 권한이 없습니다.');
} else { } else {
alert('글을 수정할 권한이 없습니다.\\n\\n회원이시라면 로그인 후 이용해 보십시오.', './login.php?'.$qstr.'&amp;url='.urlencode($_SERVER['SCRIPT_NAME'].'?bo_table='.$bo_table)); alert('글을 수정할 권한이 없습니다.\\n\\n회원이시라면 로그인 후 이용해 보십시오.', './login.php?' . $qstr . '&amp;url=' . urlencode($_SERVER['SCRIPT_NAME'] . '?bo_table=' . $bo_table));
} }
} }
$len = strlen($write['wr_reply']); $len = strlen($write['wr_reply']);
if ($len < 0) $len = 0; if ($len < 0)
$reply = substr($write['wr_reply'], 0, $len); $len = 0;
$reply = substr($write['wr_reply'], 0, $len);
// 원글만 구한다.
$sql = " select count(*) as cnt from {$write_table} // 원글만 구한다.
where wr_reply like '{$reply}%' $sql = " select count(*) as cnt from {$write_table}
and wr_id <> '{$write['wr_id']}' where wr_reply like '{$reply}%'
and wr_num = '{$write['wr_num']}' and wr_id <> '{$write['wr_id']}'
and wr_is_comment = 0 "; and wr_num = '{$write['wr_num']}'
$row = sql_fetch($sql); and wr_is_comment = 0 ";
if ($row['cnt'] && !$is_admin) $row = sql_fetch($sql);
alert('이 글과 관련된 답변글이 존재하므로 수정 할 수 없습니다.\\n\\n답변글이 있는 원글은 수정할 수 없습니다.'); if ($row['cnt'] && !$is_admin)
alert('이 글과 관련된 답변글이 존재하므로 수정 할 수 없습니다.\\n\\n답변글이 있는 원글은 수정할 수 없습니다.');
// 코멘트 달린 원글의 수정 여부
$sql = " select count(*) as cnt from {$write_table} // 코멘트 달린 원글의 수정 여부
where wr_parent = '{$wr_id}' $sql = " select count(*) as cnt from {$write_table}
and mb_id <> '{$member['mb_id']}' where wr_parent = '{$wr_id}'
and wr_is_comment = 1 "; and mb_id <> '{$member['mb_id']}'
$row = sql_fetch($sql); and wr_is_comment = 1 ";
if ($board['bo_count_modify'] && $row['cnt'] >= $board['bo_count_modify'] && !$is_admin) $row = sql_fetch($sql);
alert('이 글과 관련된 댓글이 존재하므로 수정 할 수 없습니다.\\n\\n댓글이 '.$board['bo_count_modify'].'건 이상 달린 원글은 수정할 수 없습니다.'); if ($board['bo_count_modify'] && $row['cnt'] >= $board['bo_count_modify'] && !$is_admin)
alert('이 글과 관련된 댓글이 존재하므로 수정 할 수 없습니다.\\n\\n댓글이 ' . $board['bo_count_modify'] . '건 이상 달린 원글은 수정할 수 없습니다.');
$title_msg = '글수정';
} else if ($w == 'r') { $title_msg = '글수정';
if ($member['mb_level'] < $board['bo_reply_level']) { } else if ($w == 'r') {
if ($member['mb_id']) if ($member['mb_level'] < $board['bo_reply_level']) {
alert('글을 답변할 권한이 없습니다.'); if ($member['mb_id'])
else alert('글을 답변할 권한이 없습니다.');
alert('답변글을 작성할 권한이 없습니다.\\n\\n회원이시라면 로그인 후 이용해 보십시오.', './login.php?'.$qstr.'&amp;url='.urlencode($_SERVER['SCRIPT_NAME'].'?bo_table='.$bo_table)); else
} alert('답변글을 작성할 권한이 없습니다.\\n\\n회원이시라면 로그인 후 이용해 보십시오.', './login.php?' . $qstr . '&amp;url=' . urlencode($_SERVER['SCRIPT_NAME'] . '?bo_table=' . $bo_table));
}
$tmp_point = isset($member['mb_point']) ? $member['mb_point'] : 0;
if ($tmp_point + $board['bo_write_point'] < 0 && !$is_admin) $tmp_point = isset($member['mb_point']) ? $member['mb_point'] : 0;
alert('보유하신 포인트('.number_format($member['mb_point']).')가 없거나 모자라서 글답변('.number_format($board['bo_comment_point']).')가 불가합니다.\\n\\n포인트를 적립하신 후 다시 글답변 해 주십시오.'); if ($tmp_point + $board['bo_write_point'] < 0 && !$is_admin)
alert('보유하신 포인트(' . number_format($member['mb_point']) . ')가 없거나 모자라서 글답변(' . number_format($board['bo_comment_point']) . ')가 불가합니다.\\n\\n포인트를 적립하신 후 다시 글답변 해 주십시오.');
//if (preg_match("/[^0-9]{0,1}{$wr_id}[\r]{0,1}/",$board['bo_notice']))
if (in_array((int)$wr_id, $notice_array)) //if (preg_match("/[^0-9]{0,1}{$wr_id}[\r]{0,1}/",$board['bo_notice']))
alert('공지에는 답변 할 수 없습니다.'); if (in_array((int) $wr_id, $notice_array))
alert('공지에는 답변 할 수 없습니다.');
//----------
// 4.06.13 : 비밀글을 타인이 열람할 수 있는 오류 수정 (헐랭이, 플록님께서 알려주셨습니다.) //----------
// 코멘트에는 원글의 답변이 불가하므로 // 4.06.13 : 비밀글을 타인이 열람할 수 있는 오류 수정 (헐랭이, 플록님께서 알려주셨습니다.)
if ($write['wr_is_comment']) // 코멘트에는 원글의 답변이 불가하므로
alert('정상적인 접근이 아닙니다.'); if ($write['wr_is_comment'])
alert('정상적인 접근이 아닙니다.');
// 비밀글인지를 검사
if (strstr($write['wr_option'], 'secret')) { // 비밀글인지를 검사
if ($write['mb_id']) { if (strstr($write['wr_option'], 'secret')) {
// 회원의 경우는 해당 글쓴 회원 및 관리자 if ($write['mb_id']) {
if (!($write['mb_id'] == $member['mb_id'] || $is_admin)) // 회원의 경우는 해당 글쓴 회원 및 관리자
alert('비밀글에는 자신 또는 관리자만 답변이 가능합니다.'); if (!($write['mb_id'] == $member['mb_id'] || $is_admin))
} else { alert('비밀글에는 자신 또는 관리자만 답변이 가능합니다.');
// 비회원의 경우는 비밀글에 답변이 불가함 } else {
if (!$is_admin) // 비회원의 경우는 비밀글에 답변이 불가함
alert('비회원의 비밀글에는 답변이 불가합니다.'); if (!$is_admin)
} alert('비회원의 비밀글에는 답변이 불가합니다.');
} }
//---------- }
//----------
// 게시글 배열 참조
$reply_array = &$write; // 게시글 배열 참조
$reply_array = &$write;
// 최대 답변은 테이블에 잡아놓은 wr_reply 사이즈만큼만 가능합니다.
if (strlen($reply_array['wr_reply']) == 10) // 최대 답변은 테이블에 잡아놓은 wr_reply 사이즈만큼만 가능합니다.
alert('더 이상 답변하실 수 없습니다.\\n\\n답변은 10단계 까지만 가능합니다.'); if (strlen($reply_array['wr_reply']) == 10)
alert('더 이상 답변하실 수 없습니다.\\n\\n답변은 10단계 까지만 가능합니다.');
$reply_len = strlen($reply_array['wr_reply']) + 1;
if ($board['bo_reply_order']) { $reply_len = strlen($reply_array['wr_reply']) + 1;
$begin_reply_char = 'A'; if ($board['bo_reply_order']) {
$end_reply_char = 'Z'; $begin_reply_char = 'A';
$reply_number = +1; $end_reply_char = 'Z';
$sql = " select MAX(SUBSTRING(wr_reply, {$reply_len}, 1)) as reply from {$write_table} where wr_num = '{$reply_array['wr_num']}' and SUBSTRING(wr_reply, {$reply_len}, 1) <> '' "; $reply_number = +1;
} else { $sql = " select MAX(SUBSTRING(wr_reply, {$reply_len}, 1)) as reply from {$write_table} where wr_num = '{$reply_array['wr_num']}' and SUBSTRING(wr_reply, {$reply_len}, 1) <> '' ";
$begin_reply_char = 'Z'; } else {
$end_reply_char = 'A'; $begin_reply_char = 'Z';
$reply_number = -1; $end_reply_char = 'A';
$sql = " select MIN(SUBSTRING(wr_reply, {$reply_len}, 1)) as reply from {$write_table} where wr_num = '{$reply_array['wr_num']}' and SUBSTRING(wr_reply, {$reply_len}, 1) <> '' "; $reply_number = -1;
} $sql = " select MIN(SUBSTRING(wr_reply, {$reply_len}, 1)) as reply from {$write_table} where wr_num = '{$reply_array['wr_num']}' and SUBSTRING(wr_reply, {$reply_len}, 1) <> '' ";
if ($reply_array['wr_reply']) $sql .= " and wr_reply like '{$reply_array['wr_reply']}%' "; }
$row = sql_fetch($sql); if ($reply_array['wr_reply'])
$sql .= " and wr_reply like '{$reply_array['wr_reply']}%' ";
if (!$row['reply']) $row = sql_fetch($sql);
$reply_char = $begin_reply_char;
else if ($row['reply'] == $end_reply_char) // A~Z은 26 입니다. if (!$row['reply'])
alert('더 이상 답변하실 수 없습니다.\\n\\n답변은 26개 까지만 가능합니다.'); $reply_char = $begin_reply_char;
else else if ($row['reply'] == $end_reply_char) // A~Z은 26 입니다.
$reply_char = chr(ord($row['reply']) + $reply_number); alert('더 이상 답변하실 수 없습니다.\\n\\n답변은 26개 까지만 가능합니다.');
else
$reply = $reply_array['wr_reply'] . $reply_char; $reply_char = chr(ord($row['reply']) + $reply_number);
$title_msg = '글답변'; $reply = $reply_array['wr_reply'] . $reply_char;
$write['wr_subject'] = 'Re: '.$write['wr_subject']; $title_msg = '글답변';
}
$write['wr_subject'] = 'Re: ' . $write['wr_subject'];
// 그룹접근 가능 }
if (!empty($group['gr_use_access'])) {
if ($is_guest) { // 그룹접근 가능
alert("접근 권한이 없습니다.\\n\\n회원이시라면 로그인 후 이용해 보십시오.", 'login.php?'.$qstr.'&amp;url='.urlencode($_SERVER['SCRIPT_NAME'].'?bo_table='.$bo_table)); if (!empty($group['gr_use_access'])) {
} if ($is_guest) {
alert("접근 권한이 없습니다.\\n\\n회원이시라면 로그인 후 이용해 보십시오.", 'login.php?' . $qstr . '&amp;url=' . urlencode($_SERVER['SCRIPT_NAME'] . '?bo_table=' . $bo_table));
if ($is_admin == 'super' || $group['gr_admin'] == $member['mb_id'] || $board['bo_admin'] == $member['mb_id']) { }
; // 통과
} else { if ($is_admin == 'super' || $group['gr_admin'] == $member['mb_id'] || $board['bo_admin'] == $member['mb_id']) {
// 그룹접근 ; // 통과
$sql = " select gr_id from {$g5['group_member_table']} where gr_id = '{$board['gr_id']}' and mb_id = '{$member['mb_id']}' "; } else {
$row = sql_fetch($sql); // 그룹접근
if (!$row['gr_id']) $sql = " select gr_id from {$g5['group_member_table']} where gr_id = '{$board['gr_id']}' and mb_id = '{$member['mb_id']}' ";
alert('접근 권한이 없으므로 글쓰기가 불가합니다.\\n\\n궁금하신 사항은 관리자에게 문의 바랍니다.'); $row = sql_fetch($sql);
} if (!$row['gr_id'])
} alert('접근 권한이 없으므로 글쓰기가 불가합니다.\\n\\n궁금하신 사항은 관리자에게 문의 바랍니다.');
}
// 본인확인을 사용한다면 }
if ($config['cf_cert_use'] && !$is_admin) {
// 인증된 회원만 가능 // 본인확인을 사용한다면
if ($board['bo_use_cert'] != '' && $is_guest) { if ($config['cf_cert_use'] && !$is_admin) {
alert('이 게시판은 본인확인 하신 회원님만 글쓰기가 가능합니다.\\n\\n회원이시라면 로그인 후 이용해 보십시오.', 'login.php?'.$qstr.'&amp;url='.urlencode($_SERVER['SCRIPT_NAME'].'?bo_table='.$bo_table)); // 인증된 회원만 가능
} if ($board['bo_use_cert'] != '' && $is_guest) {
alert('이 게시판은 본인확인 하신 회원님만 글쓰기가 가능합니다.\\n\\n회원이시라면 로그인 후 이용해 보십시오.', 'login.php?' . $qstr . '&amp;url=' . urlencode($_SERVER['SCRIPT_NAME'] . '?bo_table=' . $bo_table));
if ($board['bo_use_cert'] == 'cert' && !$member['mb_certify']) { }
alert('이 게시판은 본인확인 하신 회원님만 글쓰기가 가능합니다.\\n\\n회원정보 수정에서 본인확인을 해주시기 바랍니다.', G5_URL);
} if ($board['bo_use_cert'] == 'cert' && !$member['mb_certify']) {
alert('이 게시판은 본인확인 하신 회원님만 글쓰기가 가능합니다.\\n\\n회원정보 수정에서 본인확인을 해주시기 바랍니다.', G5_URL);
if ($board['bo_use_cert'] == 'adult' && !$member['mb_adult']) { }
alert('이 게시판은 본인확인으로 성인인증 된 회원님만 글쓰기가 가능합니다.\\n\\n성인인데 글쓰기가 안된다면 회원정보 수정에서 본인확인을 다시 해주시기 바랍니다.', G5_URL);
} if ($board['bo_use_cert'] == 'adult' && !$member['mb_adult']) {
alert('이 게시판은 본인확인으로 성인인증 된 회원님만 글쓰기가 가능합니다.\\n\\n성인인데 글쓰기가 안된다면 회원정보 수정에서 본인확인을 다시 해주시기 바랍니다.', G5_URL);
if ($board['bo_use_cert'] == 'hp-cert' && $member['mb_certify'] != 'hp') { }
alert('이 게시판은 휴대폰 본인확인 하신 회원님만 글읽기가 가능합니다.\\n\\n회원정보 수정에서 휴대폰 본인확인을 해주시기 바랍니다.', G5_URL);
} if ($board['bo_use_cert'] == 'hp-cert' && $member['mb_certify'] != 'hp') {
alert('이 게시판은 휴대폰 본인확인 하신 회원님만 글읽기가 가능합니다.\\n\\n회원정보 수정에서 휴대폰 본인확인을 해주시기 바랍니다.', G5_URL);
if ($board['bo_use_cert'] == 'hp-adult' && (!$member['mb_adult'] || $member['mb_certify'] != 'hp')) { }
alert('이 게시판은 휴대폰 본인확인으로 성인인증 된 회원님만 글읽기가 가능합니다.\\n\\n현재 성인인데 글읽기가 안된다면 회원정보 수정에서 휴대폰 본인확인을 다시 해주시기 바랍니다.', G5_URL);
} if ($board['bo_use_cert'] == 'hp-adult' && (!$member['mb_adult'] || $member['mb_certify'] != 'hp')) {
} alert('이 게시판은 휴대폰 본인확인으로 성인인증 된 회원님만 글읽기가 가능합니다.\\n\\n현재 성인인데 글읽기가 안된다면 회원정보 수정에서 휴대폰 본인확인을 다시 해주시기 바랍니다.', G5_URL);
}
// 글자수 제한 설정값 }
if ($is_admin || $board['bo_use_dhtml_editor'])
{ // 글자수 제한 설정값
$write_min = $write_max = 0; if ($is_admin || $board['bo_use_dhtml_editor']) {
} $write_min = $write_max = 0;
else } else {
{ $write_min = (int) $board['bo_write_min'];
$write_min = (int)$board['bo_write_min']; $write_max = (int) $board['bo_write_max'];
$write_max = (int)$board['bo_write_max']; }
}
$g5['title'] = ((G5_IS_MOBILE && $board['bo_mobile_subject']) ? $board['bo_mobile_subject'] : $board['bo_subject']) . ' ' . $title_msg;
$g5['title'] = ((G5_IS_MOBILE && $board['bo_mobile_subject']) ? $board['bo_mobile_subject'] : $board['bo_subject']).' '.$title_msg;
$is_notice = false;
$is_notice = false; $notice_checked = '';
$notice_checked = ''; if ($is_admin && $w != 'r') {
if ($is_admin && $w != 'r') { $is_notice = true;
$is_notice = true;
if ($w == 'u') {
if ($w == 'u') { // 답변 수정시 공지 체크 없음
// 답변 수정시 공지 체크 없음 if ($write['wr_reply']) {
if ($write['wr_reply']) { $is_notice = false;
$is_notice = false; } else {
} else { if (in_array((int) $wr_id, $notice_array)) {
if (in_array((int)$wr_id, $notice_array)) { $notice_checked = 'checked';
$notice_checked = 'checked'; }
} }
} }
} }
}
$is_html = false;
$is_html = false; if ($member['mb_level'] >= $board['bo_html_level'])
if ($member['mb_level'] >= $board['bo_html_level']) $is_html = true;
$is_html = true;
$is_secret = $board['bo_use_secret'];
$is_secret = $board['bo_use_secret'];
//$is_mail = false;
//$is_mail = false; //if ($config['cf_email_use'] && $board['bo_use_email'])
//if ($config['cf_email_use'] && $board['bo_use_email']) // $is_mail = true;
// $is_mail = true;
//$recv_email_checked = '';
//$recv_email_checked = ''; //if ($w == '' || strstr($write['wr_option'], 'mail'))
//if ($w == '' || strstr($write['wr_option'], 'mail')) // $recv_email_checked = 'checked';
// $recv_email_checked = 'checked';
$is_name = false;
$is_name = false; $is_password = false;
$is_password = false; $is_email = false;
$is_email = false; $is_homepage = false;
$is_homepage = false; if ($is_guest || ($is_admin && $w == 'u' && $member['mb_id'] != $write['mb_id'])) {
if ($is_guest || ($is_admin && $w == 'u' && $member['mb_id'] != $write['mb_id'])) { $is_name = true;
$is_name = true; $is_password = true;
$is_password = true; $is_email = true;
$is_email = true; $is_homepage = true;
$is_homepage = true; }
}
$is_category = false;
$is_category = false; $category_option = '';
$category_option = ''; if ($board['bo_use_category']) {
if ($board['bo_use_category']) { $ca_name = "";
$ca_name = ""; if (isset($write['ca_name']))
if (isset($write['ca_name'])) $ca_name = $write['ca_name'];
$ca_name = $write['ca_name']; $category_option = get_category_option($bo_table, $ca_name);
$category_option = get_category_option($bo_table, $ca_name); $is_category = true;
$is_category = true; }
}
$is_link = false;
$is_link = false; if ($member['mb_level'] >= $board['bo_link_level']) {
if ($member['mb_level'] >= $board['bo_link_level']) { $is_link = true;
$is_link = true; }
}
$is_file = false;
$is_file = false; if ($member['mb_level'] >= $board['bo_upload_level']) {
if ($member['mb_level'] >= $board['bo_upload_level']) { $is_file = true;
$is_file = true; }
}
$is_file_content = false;
$is_file_content = false; if ($board['bo_use_file_content']) {
if ($board['bo_use_file_content']) { $is_file_content = true;
$is_file_content = true; }
}
$file_count = (int) $board['bo_upload_count'];
$file_count = (int)$board['bo_upload_count'];
$name = "";
$name = ""; $email = "";
$email = ""; $homepage = "";
$homepage = ""; if ($w == "" || $w == "r") {
if ($w == "" || $w == "r") { if ($is_member) {
if ($is_member) { if (isset($write['wr_name'])) {
if (isset($write['wr_name'])) { $name = get_text(cut_str(stripslashes($write['wr_name']), 20));
$name = get_text(cut_str(stripslashes($write['wr_name']),20)); }
} //$email = get_email_address($member['mb_email']);
//$email = get_email_address($member['mb_email']); //$homepage = get_text(stripslashes($member['mb_homepage']));
//$homepage = get_text(stripslashes($member['mb_homepage'])); }
} }
}
$html_checked = "";
$html_checked = ""; $html_value = "";
$html_value = ""; $secret_checked = "";
$secret_checked = "";
if ($w == '') {
if ($w == '') { $password_required = 'required';
$password_required = 'required'; } else if ($w == 'u') {
} else if ($w == 'u') { $password_required = '';
$password_required = '';
if (!$is_admin) {
if (!$is_admin) { if (!($is_member && $member['mb_id'] == $write['mb_id'])) {
if (!($is_member && $member['mb_id'] == $write['mb_id'])) { if (!check_password($wr_password, $write['wr_password'])) {
if (!check_password($wr_password, $write['wr_password'])) { alert('비밀번호가 틀립니다.');
alert('비밀번호가 틀립니다.'); }
} }
} }
}
$name = get_text(cut_str(stripslashes($write['wr_name']), 20));
$name = get_text(cut_str(stripslashes($write['wr_name']),20)); //$email = get_email_address($write['wr_email']);
//$email = get_email_address($write['wr_email']); //$homepage = get_text(stripslashes($write['wr_homepage']));
//$homepage = get_text(stripslashes($write['wr_homepage']));
for ($i = 1; $i <= G5_LINK_COUNT; $i++) {
for ($i=1; $i<=G5_LINK_COUNT; $i++) { $write['wr_link' . $i] = get_text($write['wr_link' . $i]);
$write['wr_link'.$i] = get_text($write['wr_link'.$i]); $link[$i] = $write['wr_link' . $i];
$link[$i] = $write['wr_link'.$i]; }
}
if (strstr($write['wr_option'], 'html1')) {
if (strstr($write['wr_option'], 'html1')) { $html_checked = 'checked';
$html_checked = 'checked'; $html_value = 'html1';
$html_value = 'html1'; } else if (strstr($write['wr_option'], 'html2')) {
} else if (strstr($write['wr_option'], 'html2')) { $html_checked = 'checked';
$html_checked = 'checked'; $html_value = 'html2';
$html_value = 'html2'; }
}
if (strstr($write['wr_option'], 'secret')) {
if (strstr($write['wr_option'], 'secret')) { $secret_checked = 'checked';
$secret_checked = 'checked'; }
}
$file = get_file($bo_table, $wr_id);
$file = get_file($bo_table, $wr_id); if ($file_count < $file['count'])
if($file_count < $file['count']) $file_count = $file['count'];
$file_count = $file['count']; } else if ($w == 'r') {
} else if ($w == 'r') { if (strstr($write['wr_option'], 'secret')) {
if (strstr($write['wr_option'], 'secret')) { $is_secret = true;
$is_secret = true; $secret_checked = 'checked';
$secret_checked = 'checked'; }
}
$password_required = "required";
$password_required = "required";
for ($i = 1; $i <= G5_LINK_COUNT; $i++) {
for ($i=1; $i<=G5_LINK_COUNT; $i++) { $write['wr_link' . $i] = get_text($write['wr_link' . $i]);
$write['wr_link'.$i] = get_text($write['wr_link'.$i]); }
} }
}
set_session('ss_bo_table', $_REQUEST['bo_table']);
set_session('ss_bo_table', $_REQUEST['bo_table']); set_session('ss_wr_id', $_REQUEST['wr_id']);
set_session('ss_wr_id', $_REQUEST['wr_id']);
$subject = "";
$subject = ""; if (isset($write['wr_subject'])) {
if (isset($write['wr_subject'])) { $subject = str_replace("\"", "&#034;", get_text(cut_str($write['wr_subject'], 255), 0));
$subject = str_replace("\"", "&#034;", get_text(cut_str($write['wr_subject'], 255), 0)); }
}
$content = '';
$content = ''; if ($w == '') {
if ($w == '') { $content = $board['bo_insert_content'];
$content = $board['bo_insert_content']; } else if ($w == 'r') {
} else if ($w == 'r') { if (!strstr($write['wr_option'], 'html')) {
if (!strstr($write['wr_option'], 'html')) { $content = "\n\n\n &gt; "
$content = "\n\n\n &gt; " . "\n &gt; "
."\n &gt; " . "\n &gt; " . str_replace("\n", "\n> ", get_text($write['wr_content'], 0))
."\n &gt; ".str_replace("\n", "\n> ", get_text($write['wr_content'], 0)) . "\n &gt; "
."\n &gt; " . "\n &gt; ";
."\n &gt; ";
}
} } else {
} else { $content = get_text($write['wr_content'], 0);
$content = get_text($write['wr_content'], 0); }
}
$upload_max_filesize = number_format($board['bo_upload_size']) . ' 바이트';
$upload_max_filesize = number_format($board['bo_upload_size']) . ' 바이트';
$width = $board['bo_table_width'];
$width = $board['bo_table_width']; if ($width <= 100)
if ($width <= 100) $width .= '%';
$width .= '%'; else
else $width .= 'px';
$width .= 'px';
$is_dhtml_editor = false;
$is_dhtml_editor = false; $is_dhtml_editor_use = false;
$is_dhtml_editor_use = false; $editor_content_js = '';
$editor_content_js = ''; if (!is_mobile() || defined('G5_IS_MOBILE_DHTML_USE') && G5_IS_MOBILE_DHTML_USE)
if(!is_mobile() || defined('G5_IS_MOBILE_DHTML_USE') && G5_IS_MOBILE_DHTML_USE) $is_dhtml_editor_use = true;
$is_dhtml_editor_use = true;
// 모바일에서는 G5_IS_MOBILE_DHTML_USE 설정에 따라 DHTML 에디터 적용
// 모바일에서는 G5_IS_MOBILE_DHTML_USE 설정에 따라 DHTML 에디터 적용 if ($config['cf_editor'] && $is_dhtml_editor_use && $board['bo_use_dhtml_editor'] && $member['mb_level'] >= $board['bo_html_level']) {
if ($config['cf_editor'] && $is_dhtml_editor_use && $board['bo_use_dhtml_editor'] && $member['mb_level'] >= $board['bo_html_level']) { $is_dhtml_editor = true;
$is_dhtml_editor = true;
if (is_file(G5_EDITOR_PATH . '/' . $config['cf_editor'] . '/autosave.editor.js'))
if(is_file(G5_EDITOR_PATH.'/'.$config['cf_editor'].'/autosave.editor.js')) $editor_content_js = '<script src="' . G5_EDITOR_URL . '/' . $config['cf_editor'] . '/autosave.editor.js"></script>' . PHP_EOL;
$editor_content_js = '<script src="'.G5_EDITOR_URL.'/'.$config['cf_editor'].'/autosave.editor.js"></script>'.PHP_EOL; }
} $editor_html = editor_html('wr_content', $content, $is_dhtml_editor);
$editor_html = editor_html('wr_content', $content, $is_dhtml_editor); $editor_js = '';
$editor_js = ''; $editor_js .= get_editor_js('wr_content', $is_dhtml_editor);
$editor_js .= get_editor_js('wr_content', $is_dhtml_editor); $editor_js .= chk_editor_js('wr_content', $is_dhtml_editor);
$editor_js .= chk_editor_js('wr_content', $is_dhtml_editor);
// 임시 저장된 글 수
// 임시 저장된 글 수 $autosave_count = autosave_count($member['mb_id']);
$autosave_count = autosave_count($member['mb_id']);
$action_url = https_url(G5_BBS_DIR) . "/write_update.php";
$action_url = https_url(G5_BBS_DIR)."/write_update.php";
echo '<!-- skin : ' . (G5_IS_MOBILE ? $board['bo_mobile_skin'] : $board['bo_skin']) . ' -->';
echo '<!-- skin : '.(G5_IS_MOBILE ? $board['bo_mobile_skin'] : $board['bo_skin']).' -->'; include_once $board_skin_path . '/write.skin.php';
include_once ($board_skin_path.'/write.skin.php');
?>

View file

@ -1,86 +1,90 @@
<? <?php
if (!defined("_GNUBOARD_")) exit; // 개별 페이지 접근 불가 if (!defined("_GNUBOARD_"))
exit;
add_stylesheet('<link rel="stylesheet" href="'.$board_skin_url.'/style.css">', 0);
$option = ''; add_stylesheet('<link rel="stylesheet" href="' . $board_skin_url . '/style.css">', 0);
$option_hidden = ''; $option = '';
if ($is_notice || $is_html || $is_secret || $is_mail) { $option_hidden = '';
$option = ''; if ($is_notice || $is_html || $is_secret || $is_mail) {
if ($is_notice) { $option = '';
// $option .= "\n".'<input type="checkbox" id="notice" name="notice" value="1" '.$notice_checked.'>'."\n".'<label for="notice">공지</label>'; if ($is_notice) {
} // $option .= "\n".'<input type="checkbox" id="notice" name="notice" value="1" '.$notice_checked.'>'."\n".'<label for="notice">공지</label>';
}
if ($is_html) {
if ($is_dhtml_editor) { if ($is_html) {
$option_hidden .= '<input type="hidden" value="html1" name="html">'; if ($is_dhtml_editor) {
} else { $option_hidden .= '<input type="hidden" value="html1" name="html">';
//$option .= "\n".'<input type="checkbox" id="html" name="html" onclick="html_auto_br(this);" value="'.$html_value.'" '.$html_checked.'>'."\n".'<label for="html">html</label>'; } else {
} //$option .= "\n".'<input type="checkbox" id="html" name="html" onclick="html_auto_br(this);" value="'.$html_value.'" '.$html_checked.'>'."\n".'<label for="html">html</label>';
} }
}
if ($is_secret) {
if ($is_admin || $is_secret==1) { if ($is_secret) {
$option .= "\n".'<label for="secret" style="white-space:nowrap;"><input type="checkbox" id="secret" name="secret" value="secret" '.$secret_checked.'>'."\n".'비밀글</label>'; if ($is_admin || $is_secret == 1) {
} else { $option .= "\n" . '<label for="secret" style="white-space:nowrap;"><input type="checkbox" id="secret" name="secret" value="secret" ' . $secret_checked . '>' . "\n" . '비밀글</label>';
$option_hidden .= '<input type="hidden" name="secret" value="secret">'; } else {
} $option_hidden .= '<input type="hidden" name="secret" value="secret">';
} }
}
//if ($is_mail) {
// $option .= "\n".'<input type="checkbox" id="mail" name="mail" value="mail" '.$recv_email_checked.'>'."\n".'<label for="mail">답변메일받기</label>'; //if ($is_mail) {
//} // $option .= "\n".'<input type="checkbox" id="mail" name="mail" value="mail" '.$recv_email_checked.'>'."\n".'<label for="mail">답변메일받기</label>';
} //}
}
echo $option_hidden;
echo $option_hidden;
?>
<form name="fwrite" id="fwrite" action="<?php echo $action_url ?>" onsubmit="return fwrite_submit(this);" method="post" enctype="multipart/form-data" autocomplete="off"> ?>
<input type="hidden" name="uid" value="<?php echo get_uniqid(); ?>"> <form name="fwrite" id="fwrite" action="<?php echo $action_url ?>" onsubmit="return fwrite_submit(this);" method="post"
<input type="hidden" name="w" value="<?php echo $w ?>"> enctype="multipart/form-data" autocomplete="off">
<input type="hidden" name="bo_table" value="<?php echo $bo_table ?>"> <input type="hidden" name="uid" value="<?php echo get_uniqid(); ?>">
<input type="hidden" name="wr_id" value="<?php echo $wr_id ?>"> <input type="hidden" name="w" value="<?php echo $w ?>">
<input type="hidden" name="sca" value="<?php echo $sca ?>"> <input type="hidden" name="bo_table" value="<?php echo $bo_table ?>">
<input type="hidden" name="sfl" value="<?php echo $sfl ?>"> <input type="hidden" name="wr_id" value="<?php echo $wr_id ?>">
<input type="hidden" name="stx" value="<?php echo $stx ?>"> <input type="hidden" name="sca" value="<?php echo $sca ?>">
<input type="hidden" name="spt" value="<?php echo $spt ?>"> <input type="hidden" name="sfl" value="<?php echo $sfl ?>">
<input type="hidden" name="sst" value="<?php echo $sst ?>"> <input type="hidden" name="stx" value="<?php echo $stx ?>">
<input type="hidden" name="sod" value="<?php echo $sod ?>"> <input type="hidden" name="spt" value="<?php echo $spt ?>">
<input type="hidden" name="page" value="<?php echo $page ?>"> <input type="hidden" name="sst" value="<?php echo $sst ?>">
<input type="hidden" name="wr_subject" value="<?=$board['bo_subject']?>"> <input type="hidden" name="sod" value="<?php echo $sod ?>">
<?= $option_hidden ?> <input type="hidden" name="page" value="<?php echo $page ?>">
<div class="ui-write-box ui-text-area<?=$w=='u'? " update":"";?>"> <input type="hidden" name="wr_subject" value="<?= $board['bo_subject'] ?>">
<a href="#" class="write_open ui-btn point">+</a> <?= $option_hidden ?>
<p> <div class="ui-write-box ui-text-area<?= $w == 'u' ? " update" : ""; ?>">
<input type="text" name="wr_content" id="content" class="frm-input full" required value="<?=$content?>"> <a href="#" class="write_open ui-btn point">+</a>
<button type="submit" id="btn_submit" class="ui-btn" accesskey='s'>입력</button><?if($w=='u'){?><a href="<?=G5_BBS_URL?>/board.php?bo_table=<?=$bo_table?>" class="ui-btn etc">뒤로</a><?}?> <p>
<? if(!$is_member){ ?> <input type="text" name="wr_content" id="content" class="frm-input full" required value="<?= $content ?>">
<input type="text" maxlength="20" name="wr_name" id="wr_name" placeholder="이름" required value="<?=$name?>" /> <button type="submit" id="btn_submit" class="ui-btn" accesskey='s'>입력</button><?php if ($w == 'u') { ?><a
<input type="password" maxlength="20" id="wr_password" name="wr_password" placeholder="비밀번호" value="<?=$password?>" <?=$password_required?> /> href="<?= G5_BBS_URL ?>/board.php?bo_table=<?= $bo_table ?>" class="ui-btn etc">뒤로</a><?php } ?>
<? } ?> <?php if (!$is_member) { ?>
<?php if ($option) { ?> <input type="text" maxlength="20" name="wr_name" id="wr_name" placeholder="이름" required
&nbsp;&nbsp;<?php echo $option ?> value="<?= $name ?>" />
<?php } ?> <input type="password" maxlength="20" id="wr_password" name="wr_password" placeholder="비밀번호"
</p> value="<?= $password ?>" <?= $password_required ?> />
</div> <?php } ?>
</form> <?php if ($option) { ?>
&nbsp;&nbsp;<?php echo $option ?>
<script> <?php } ?>
<?php if($write_min || $write_max) { ?> </p>
// 글자수 제한 </div>
var char_min = parseInt(<?php echo $write_min; ?>); // 최소 </form>
var char_max = parseInt(<?php echo $write_max; ?>); // 최대
check_byte("wr_content", "char_count"); <script>
<?php if ($write_min || $write_max) { ?>
$(function() { // 글자수 제한
$("#wr_content").on("keyup", function() { var char_min = parseInt(<?php echo $write_min; ?>); // 최소
check_byte("wr_content", "char_count"); var char_max = parseInt(<?php echo $write_max; ?>); // 최대
}); check_byte("wr_content", "char_count");
});
$(function () {
<?php } ?> $("#wr_content").on("keyup", function () {
check_byte("wr_content", "char_count");
function fwrite_submit(f) });
{ });
return true;
} <?php } ?>
</script>
function fwrite_submit(f) {
return true;
}
</script>

View file

@ -1,6 +1,6 @@
<? <?php
if (!defined("_GNUBOARD_")) exit; // 개별 페이지 접근 불가 if (!defined("_GNUBOARD_"))
exit;
// 자신만의 코드를 넣어주세요.
goto_url("./board.php?bo_table=$bo_table"); // 자신만의 코드를 넣어주세요.
?> goto_url("./board.php?bo_table=$bo_table");