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

게시글 삭제 오류 채택완료

summer1 3년 전 조회 2,436

 

 

안녕하세요. 게시글 삭제 오류 문의드립니다.

 

게시판에서 선택 후 삭제 또는 게시글 선택하여 view상태에서  삭제 시 

화면이 새로고침 되며 list 로 이동됩니다.

 

어떻게 해결할 수 있을까요?

 

그누보드 버전은 5.1.4이고, delet.php 파일은 아래와 같습니다.

 

 

 

<?php
include_once('./_common.php');


if ($is_admin)
{
    if (!($token && get_session('ss_delete_token') == $token))
        alert('토큰 에러로 삭제 불가합니다.');
}

$wr = sql_fetch(" select * from $write_table where wr_id = '$wr_id' ");

@include_once($board_skin_path.'/delete.head.skin.php');

if ($is_admin == 'super') // 최고관리자 통과
    ;
else if ($is_admin == 'group') { // 그룹관리자
    $mb = get_member($write['mb_id']);
    if ($member['mb_id'] != $group['gr_admin']) // 자신이 관리하는 그룹인가?
        alert('자신이 관리하는 그룹의 게시판이 아니므로 삭제할 수 없습니다.');
    else if ($member['mb_level'] < $mb['mb_level']) // 자신의 레벨이 크거나 같다면 통과
        alert('자신의 권한보다 높은 권한의 회원이 작성한 글은 삭제할 수 없습니다.');
} else if ($is_admin == 'board') { // 게시판관리자이면
    $mb = get_member($write['mb_id']);
    if ($member['mb_id'] != $board['bo_admin']) // 자신이 관리하는 게시판인가?
        alert('자신이 관리하는 게시판이 아니므로 삭제할 수 없습니다.');
    else if ($member['mb_level'] < $mb['mb_level']) // 자신의 레벨이 크거나 같다면 통과
        alert('자신의 권한보다 높은 권한의 회원이 작성한 글은 삭제할 수 없습니다.');
} else if ($member['mb_id']) {
    if ($member['mb_id'] != $write['mb_id'])
        alert('자신의 글이 아니므로 삭제할 수 없습니다.');
} else {
    if ($write['mb_id'])
        alert('로그인 후 삭제하세요.', './login.php?url='.urlencode('./board.php?bo_table='.$bo_table.'&amp;wr_id='.$wr_id));
    else if (!check_password($wr_password, $write['wr_password']))
        alert('비밀번호가 틀리므로 삭제할 수 없습니다.');
}

$len = strlen($write['wr_reply']);
if ($len < 0) $len = 0;
$reply = substr($write['wr_reply'], 0, $len);

// 원글만 구한다.
$sql = " select count(*) as cnt from $write_table
            where wr_reply like '$reply%'
            and wr_id <> '{$write['wr_id']}'
            and wr_num = '{$write['wr_num']}'
            and wr_is_comment = 0 ";
$row = sql_fetch($sql);
if ($row['cnt'] && !$is_admin)
    alert('이 글과 관련된 답변글이 존재하므로 삭제 할 수 없습니다.\\n\\n우선 답변글부터 삭제하여 주십시오.');

// 코멘트 달린 원글의 삭제 여부
$sql = " select count(*) as cnt from $write_table
            where wr_parent = '$wr_id'
            and mb_id <> '{$member['mb_id']}'
            and wr_is_comment = 1 ";
$row = sql_fetch($sql);
if ($row['cnt'] >= $board['bo_count_delete'] && !$is_admin)
    alert('이 글과 관련된 코멘트가 존재하므로 삭제 할 수 없습니다.\\n\\n코멘트가 '.$board['bo_count_delete'].'건 이상 달린 원글은 삭제할 수 없습니다.');


// 사용자 코드 실행
@include_once($board_skin_path.'/delete.skin.php');


// 나라오름님 수정 : 원글과 코멘트수가 정상적으로 업데이트 되지 않는 오류를 잡아 주셨습니다.
//$sql = " select wr_id, mb_id, wr_comment from $write_table where wr_parent = '$write[wr_id]' order by wr_id ";
$sql = " select wr_id, mb_id, wr_is_comment, wr_content from $write_table where wr_parent = '{$write['wr_id']}' order by wr_id ";
$result = sql_query($sql);
while ($row = sql_fetch_array($result))
{
    // 원글이라면
    if (!$row['wr_is_comment'])
    {
        // 원글 포인트 삭제
        if (!delete_point($row['mb_id'], $bo_table, $row['wr_id'], '쓰기'))
            insert_point($row['mb_id'], $board['bo_write_point'] * (-1), "{$board['bo_subject']} {$row['wr_id']} 글삭제");

        // 업로드된 파일이 있다면 파일삭제
        $sql2 = " select * from {$g5['board_file_table']} where bo_table = '$bo_table' and wr_id = '{$row['wr_id']}' ";
        $result2 = sql_query($sql2);
        while ($row2 = sql_fetch_array($result2)) {
            @unlink(G5_DATA_PATH.'/file/'.$bo_table.'/'.$row2['bf_file']);
            // 썸네일삭제
            if(preg_match("/\.({$config['cf_image_extension']})$/i", $row2['bf_file'])) {
                delete_board_thumbnail($bo_table, $row2['bf_file']);
            }
        }

        // 에디터 썸네일 삭제
        delete_editor_thumbnail($row['wr_content']);

        // 파일테이블 행 삭제
        sql_query(" delete from {$g5['board_file_table']} where bo_table = '$bo_table' and wr_id = '{$row['wr_id']}' ");

        $count_write++;
    }
    else
    {
        // 코멘트 포인트 삭제
        if (!delete_point($row['mb_id'], $bo_table, $row['wr_id'], '댓글'))
            insert_point($row['mb_id'], $board['bo_comment_point'] * (-1), "{$board['bo_subject']} {$write['wr_id']}-{$row['wr_id']} 댓글삭제");

        $count_comment++;
    }
}

// 게시글 삭제
sql_query(" delete from $write_table where wr_parent = '{$write['wr_id']}' ");

// 최근게시물 삭제
sql_query(" delete from {$g5['board_new_table']} where bo_table = '$bo_table' and wr_parent = '{$write['wr_id']}' ");

// 스크랩 삭제
sql_query(" delete from {$g5['scrap_table']} where bo_table = '$bo_table' and wr_id = '{$write['wr_id']}' ");

/*
// 공지사항 삭제
$notice_array = explode("\n", trim($board['bo_notice']));
$bo_notice = "";
for ($k=0; $k<count($notice_array); $k++)
    if ((int)$write[wr_id] != (int)$notice_array[$k])
        $bo_notice .= $notice_array[$k] . "\n";
$bo_notice = trim($bo_notice);
*/
$bo_notice = board_notice($board['bo_notice'], $write['wr_id']);
sql_query(" update {$g5['board_table']} set bo_notice = '$bo_notice' where bo_table = '$bo_table' ");

// 글숫자 감소
if ($count_write > 0 || $count_comment > 0)
    sql_query(" update {$g5['board_table']} set bo_count_write = bo_count_write - '$count_write', bo_count_comment = bo_count_comment - '$count_comment' where bo_table = '$bo_table' ");

@include_once($board_skin_path.'/delete.tail.skin.php');

delete_cache_latest($bo_table);

goto_url('./board.php?bo_table='.$bo_table.'&amp;page='.$page.$qstr);
?>
 

 

 

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

답변 5개

채택된 답변
+20 포인트

board_skin_path 변수는


common.php:    $board_skin_path    = get_skin_path('board', $board['bo_mobile_skin']);
common.php:    $board_skin_path    = get_skin_path('board', $board['bo_skin']);
 

여기서 지정되는데 어떤 이유로 값이 변경되었습니다.

 

소스를 따라가면 확인해 보는 수밖에는 없겠네요.

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

답변에 대한 댓글 1개

s
summer1
3년 전
감사합니다. 천천히 확인해보겠습니다.

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

@include_once($board_skin_path.'/delete.head.skin.php');

// 사용자 코드 실행
@include_once($board_skin_path.'/delete.skin.php');

 

===

 

이 파일 내용은 어떤 게 있나요?

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

답변에 대한 댓글 3개

s
summer1
3년 전
/www/bbs 폴더에는 해당 파일이 안 보이는데 파일 위치를 어떻게 찾으면 될까요 ?
엑스엠엘
3년 전
echo ($board_skin_path.'/delete.skin.php');
exit;
이렇게 하면 폴더 위치를 알 수 있습니다.
또는 게시판 설정에서 스킨 명을 가지고 폴더 위치를 알아 낼 수도 있구요.
s
summer1
3년 전
/www/skin/board//delete.skin.php

위치는 이렇게 나오고, 현재 사용중인 게시판 스킨 폴더는
/www/skin/board/basic 입니다.

delete.skin.php 파일은 존재하지 않는데, 혹시 이 파일이 없어서 삭제가 안 되는 걸까요?

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

view.skin.php에서

해당 버튼 클릭시 javascript 오류가 있는지 확인해 보세요.

 

브라우저에서 bbs/delete.php 주소로 넘어 가는지 확인해 보세요.

 

alert() 창은 안 뜨나요?

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

답변에 대한 댓글 3개

s
summer1
3년 전
<?php if ($delete_href) { ?><li><a href="<?php echo $delete_href ?>" class="btn_b01" onclick="del(this.href); return false;">삭제</a></li><?php } ?>

view.skin.php에서 삭제 관련 코드는 이렇게 하나 있습니다.
삭제 시 자동으로 뜨게 해 둔 알림창은 정상적으로 뜨고 있고, 오류 관련 alert() 창은 뜨지 않습니다.
엑스엠엘
3년 전
javascript del() 함수 내용도 올려 보세요.
s
summer1
3년 전
아 .. 같은 페이지에는 해당 함수가 없습니다. /www/js 폴더의 common.js 파일에 있는 삭제 함수입니다. 이거면 될까요?




// 삭제 검사 확인
function del(href)
{
if(confirm("한번 삭제한 자료는 복구할 방법이 없습니다.\n\n정말 삭제하시겠습니까?")) {
var iev = -1;
if (navigator.appName == 'Microsoft Internet Explorer') {
var ua = navigator.userAgent;
var re = new RegExp("MSIE ([0-9]{1,}[\.0-9]{0,})");
if (re.exec(ua) != null)
iev = parseFloat(RegExp.$1);
}

// IE6 이하에서 한글깨짐 방지
if (iev != -1 && iev < 7) {
document.location.href = encodeURI(href);
} else {
document.location.href = href;
}
}
}

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

이건 로직이 맞는데요

왜냐면 게시판 글이 삭제되면 아무것도 없는거잖아요 그럼 목록으로 이동해야되죠 

뭐가 문제인가요?

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

답변에 대한 댓글 4개

s
summer1
3년 전
게시글이 삭제되지 않습니다.
릴보이즈
3년 전
캐시 삭제 해보셨나요
s
summer1
3년 전
네 캐시 삭제해도 해결되지 않습니다 ㅠㅠ
릴보이즈
3년 전
음.. 젤 쉬운방법은 최신버전 그누 다운 받아서 저부분 파일만 덮어씌우면 될것같은데요

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

플라이
3년 전

삭제후 게시글이 존재하지 않기에 이동되며 리스트로 가는게 맞는데요

어떻게 원하시는걸까요?

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

답변에 대한 댓글 3개

s
summer1
3년 전
게시글이 삭제되지 않은 채로 리스트로 이동되는 문제입니다.
플라이
3년 전
delete쿼리가 제대로 반응을 안하는 부분인데 wr_id값이 제대로 전달되어 쿼리가 실행되는지를 체크해 보셔야 합니다.
s
summer1
3년 전
체크하는 방법 알려주실 수 있나요? 초보라서 간단한 내용도 방법을 몰라 어렵네요 ㅠ

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

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

로그인