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

순정 게시판 등록이 안될때 채택완료

박강현 4년 전 조회 1,822

안녕하세요 !

 

제목 그대로 입니다.

그누보드 순정과 비교해도 아무런 차이가 없는데

 

현재 공지(notice) 게시판에 등록을 하면 db로 값이 넘어가지지가 않습니다.

 

혹시 어떤부분을 봐야할지 여쭤볼수 있을까요?

또는, write_update.skin.php 등을 생성해서 수동으로 입력할 수 있을까요?

 

*소스코드는 현재 순정 write 부분만 올려드리겠습니다.

 

</p>

<p><?php

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

<p>// add_stylesheet('css 구문', 출력순서); 숫자가 작을 수록 먼저 출력됨

add_stylesheet('<link rel="stylesheet" href="'.$board_skin_url.'/style.css">', 0);

?></p>

<p><section id="bo_w" class="sub_container">

    <h2 class="sound_only"><?php echo $g5['title'] ?></h2></p>

<p>    <!-- 게시물 작성/수정 시작 { -->

    <form name="fwrite" id="fwrite" action="<?php echo $action_url ?>" onsubmit="return fwrite_submit(this);" method="post" enctype="multipart/form-data" autocomplete="off" style="width:<?php echo $width; ?>">

    <input type="hidden" name="uid" value="<?php echo get_uniqid(); ?>">

    <input type="hidden" name="w" value="<?php echo $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="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="sst" value="<?php echo $sst ?>">

    <input type="hidden" name="sod" value="<?php echo $sod ?>">

    <input type="hidden" name="page" value="<?php echo $page ?>">

    <?php

    $option = '';

    $option_hidden = '';

    if ($is_notice || $is_html || $is_secret || $is_mail) { 

        $option = '';

        if ($is_notice) {

            $option .= PHP_EOL.'<li class="chk_box"><input type="checkbox" id="notice" name="notice"  class="selec_chk" value="1" '.$notice_checked.'>'.PHP_EOL.'<label for="notice"><span></span>공지</label></li>';

        }

        if ($is_html) {

            if ($is_dhtml_editor) {

                $option_hidden .= '<input type="hidden" value="html1" name="html">';

            } else {

                $option .= PHP_EOL.'<li class="chk_box"><input type="checkbox" id="html" name="html" onclick="html_auto_br(this);" class="selec_chk" value="'.$html_value.'" '.$html_checked.'>'.PHP_EOL.'<label for="html"><span></span>html</label></li>';

            }

        }

        if ($is_secret) {

            if ($is_admin || $is_secret==1) {

                $option .= PHP_EOL.'<li class="chk_box"><input type="checkbox" id="secret" name="secret"  class="selec_chk" value="secret" '.$secret_checked.'>'.PHP_EOL.'<label for="secret"><span></span>비밀글</label></li>';

            } else {

                $option_hidden .= '<input type="hidden" name="secret" value="secret">';

            }

        }

        if ($is_mail) {

            $option .= PHP_EOL.'<li class="chk_box"><input type="checkbox" id="mail" name="mail"  class="selec_chk" value="mail" '.$recv_email_checked.'>'.PHP_EOL.'<label for="mail"><span></span>답변메일받기</label></li>';

        }

    }

    echo $option_hidden;

    ?></p>

<p>    <?php if ($is_category) { ?>

    <div class="bo_w_select write_div">

        <label for="ca_name" class="sound_only">분류<strong>필수</strong></label>

        <select name="ca_name" id="ca_name" required>

            <option value="">분류를 선택하세요</option>

            <?php echo $category_option ?>

        </select>

    </div>

    <?php } ?></p>

<p>    <div class="bo_w_info write_div">

        <?php if ($is_name) { ?>

            <label for="wr_name" class="sound_only">이름<strong>필수</strong></label>

            <input type="text" name="wr_name" value="<?php echo $name ?>" id="wr_name" required class="frm_input half_input required" placeholder="이름">

        <?php } ?>

    

        <?php if ($is_password) { ?>

            <label for="wr_password" class="sound_only">비밀번호<strong>필수</strong></label>

            <input type="password" name="wr_password" id="wr_password" <?php echo $password_required ?> class="frm_input half_input <?php echo $password_required ?>" placeholder="비밀번호">

        <?php } ?>

    

        <?php if ($is_email) { ?>

            <label for="wr_email" class="sound_only">이메일</label>

            <input type="text" name="wr_email" value="<?php echo $email ?>" id="wr_email" class="frm_input half_input email " placeholder="이메일">

        <?php } ?>

        

    

        <?php if ($is_homepage) { ?>

            <label for="wr_homepage" class="sound_only">홈페이지</label>

            <input type="text" name="wr_homepage" value="<?php echo $homepage ?>" id="wr_homepage" class="frm_input half_input" size="50" placeholder="홈페이지">

        <?php } ?>

    </div>

    

    <?php if ($option) { ?>

    <div class="write_div">

        <span class="sound_only">옵션</span>

        <ul class="bo_v_option">

        <?php echo $option ?>

        </ul>

    </div>

    <?php } ?></p>

<p>    <div class="bo_w_tit write_div">

        <label for="wr_subject" class="sound_only">제목<strong>필수</strong></label>

        

        <div id="autosave_wrapper" class="write_div">

            <input type="text" name="wr_subject" value="<?php echo $subject ?>" id="wr_subject" required class="frm_input full_input required" size="50" maxlength="255" placeholder="제목">

            <?php if ($is_member) { // 임시 저장된 글 기능 ?>

            <script src="<?php echo G5_JS_URL; ?>/autosave.js"></script>

            <?php if($editor_content_js) echo $editor_content_js; ?>

            <button type="button" id="btn_autosave" class="btn_frmline">임시 저장된 글 (<span id="autosave_count"><?php echo $autosave_count; ?></span>)</button>

            <div id="autosave_pop">

                <strong>임시 저장된 글 목록</strong>

                <ul></ul>

                <div><button type="button" class="autosave_close">닫기</button></div>

            </div>

            <?php } ?>

        </div>

        

    </div></p>

<p>    <div class="write_div">

        <label for="wr_content" class="sound_only">내용<strong>필수</strong></label>

        <div class="wr_content <?php echo $is_dhtml_editor ? $config['cf_editor'] : ''; ?>">

            <?php if($write_min || $write_max) { ?>

            <!-- 최소/최대 글자 수 사용 시 -->

            <p id="char_count_desc">이 게시판은 최소 <strong><?php echo $write_min; ?></strong>글자 이상, 최대 <strong><?php echo $write_max; ?></strong>글자 이하까지 글을 쓰실 수 있습니다.</p>

            <?php } ?>

            <?php echo $editor_html; // 에디터 사용시는 에디터로, 아니면 textarea 로 노출 ?>

            <?php if($write_min || $write_max) { ?>

            <!-- 최소/최대 글자 수 사용 시 -->

            <div id="char_count_wrap"><span id="char_count"></span>글자</div>

            <?php } ?>

        </div>

        

    </div></p>

<p>    <?php for ($i=1; $is_link && $i<=G5_LINK_COUNT; $i++) { ?>

    <div class="bo_w_link write_div">

        <label for="wr_link<?php echo $i ?>"><i class="fa fa-link" aria-hidden="true"></i><span class="sound_only"> 링크  #<?php echo $i ?></span></label>

        <input type="text" name="wr_link<?php echo $i ?>" value="<?php if($w=="u"){ echo $write['wr_link'.$i]; } ?>" id="wr_link<?php echo $i ?>" class="frm_input full_input" size="50">

    </div>

    <?php } ?></p>

<p>    <?php for ($i=0; $is_file && $i<$file_count; $i++) { ?>

    <div class="bo_w_flie write_div">

        <div class="file_wr write_div">

            <label for="bf_file_<?php echo $i+1 ?>" class="lb_icon"><i class="fa fa-folder-open" aria-hidden="true"></i><span class="sound_only"> 파일 #<?php echo $i+1 ?></span></label>

            <input type="file" name="bf_file[]" id="bf_file_<?php echo $i+1 ?>" title="파일첨부 <?php echo $i+1 ?> : 용량 <?php echo $upload_max_filesize ?> 이하만 업로드 가능" class="frm_file ">

        </div>

        <?php if ($is_file_content) { ?>

        <input type="text" name="bf_content[]" value="<?php echo ($w == 'u') ? $file[$i]['bf_content'] : ''; ?>" title="파일 설명을 입력해주세요." class="full_input frm_input" size="50" placeholder="파일 설명을 입력해주세요.">

        <?php } ?></p>

<p>        <?php if($w == 'u' && $file[$i]['file']) { ?>

        <span class="file_del">

            <input type="checkbox" id="bf_file_del<?php echo $i ?>" name="bf_file_del[<?php echo $i;  ?>]" value="1"> <label for="bf_file_del<?php echo $i ?>"><?php echo $file[$i]['source'].'('.$file[$i]['size'].')';  ?> 파일 삭제</label>

        </span>

        <?php } ?>

        

    </div>

    <?php } ?></p>

<p>

    <?php if ($is_use_captcha) { //자동등록방지  ?>

    <div class="write_div">

        <?php echo $captcha_html ?>

    </div>

    <?php } ?></p>

<p>    <div class="btn_confirm write_div">

        <a href="<?php echo get_pretty_url($bo_table); ?>" class="btn_cancel btn">취소</a>

        <button type="submit" id="btn_submit" accesskey="s" class="btn_submit btn">작성완료</button>

    </div>

    </form></p>

<p>    <script>

    <?php if($write_min || $write_max) { ?>

    // 글자수 제한

    var char_min = parseInt(<?php echo $write_min; ?>); // 최소

    var char_max = parseInt(<?php echo $write_max; ?>); // 최대

    check_byte("wr_content", "char_count");</p>

<p>    $(function() {

        $("#wr_content").on("keyup", function() {

            check_byte("wr_content", "char_count");

        });

    });</p>

<p>    <?php } ?>

    function html_auto_br(obj)

    {

        if (obj.checked) {

            result = confirm("자동 줄바꿈을 하시겠습니까?\n\n자동 줄바꿈은 게시물 내용중 줄바뀐 곳을
태그로 변환하는 기능입니다.");

            if (result)

                obj.value = "html2";

            else

                obj.value = "html1";

        }

        else

            obj.value = "";

    }</p>

<p>    function fwrite_submit(f)

    {

        <?php echo $editor_js; // 에디터 사용시 자바스크립트에서 내용을 폼필드로 넣어주며 내용이 입력되었는지 검사함   ?></p>

<p>        var subject = "";

        var content = "";

        $.ajax({

            url: g5_bbs_url+"/ajax.filter.php",

            type: "POST",

            data: {

                "subject": f.wr_subject.value,

                "content": f.wr_content.value

            },

            dataType: "json",

            async: false,

            cache: false,

            success: function(data, textStatus) {

                subject = data.subject;

                content = data.content;

            }

        });</p>

<p>        if (subject) {

            alert("제목에 금지단어('"+subject+"')가 포함되어있습니다");

            f.wr_subject.focus();

            return false;

        }</p>

<p>        if (content) {

            alert("내용에 금지단어('"+content+"')가 포함되어있습니다");

            if (typeof(ed_wr_content) != "undefined")

                ed_wr_content.returnFalse();

            else

                f.wr_content.focus();

            return false;

        }</p>

<p>        if (document.getElementById("char_count")) {

            if (char_min > 0 || char_max > 0) {

                var cnt = parseInt(check_byte("wr_content", "char_count"));

                if (char_min > 0 && char_min > cnt) {

                    alert("내용은 "+char_min+"글자 이상 쓰셔야 합니다.");

                    return false;

                }

                else if (char_max > 0 && char_max < cnt) {

                    alert("내용은 "+char_max+"글자 이하로 쓰셔야 합니다.");

                    return false;

                }

            }

        }</p>

<p>        <?php echo $captcha_js; // 캡챠 사용시 자바스크립트에서 입력된 캡챠를 검사함  ?></p>

<p>        document.getElementById("btn_submit").disabled = "disabled";</p>

<p>        return true;

    }

    </script>

</section>

<!-- } 게시물 작성/수정 끝 --></p>

<p>

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

답변 2개

채택된 답변
+20 포인트

현재 공지(notice) 게시판에 등록을 하면 db로 값이 넘어가지지가 않습니다.

==

A, 브라우저에서 다음 페이지로 안 넘어 간다는 것인지

B, DB에 저장이 안 된다는 것인지 구분해야 합니다.

 

A는 보통 write.php에서 자바스크립트 오류일 가능성이 있고

B는 query문 오류일 가능성이 있습니다.

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

답변에 대한 댓글 5개

박강현
4년 전
답변 감사합니다.

현재 다음페이지로는 넘어 가집니다.
(write.skin.php 에서 등록 버튼 누를시 -> list.skin.php)

순정 그대로 뒀는데 query 문의 오류라면 혹시 어디쪽을 봐야할까요?
엑스엠엘
4년 전
글 등록이 안 되는 것이면
bbs/write_update.php: 290 라인 근처
여기 insert query문을 살펴 보시면 됩니다.

sql_query($sql, true);
exit;
이렇게 하시면 에러 메시지를 확인하실 수 있습니다.
박강현
4년 전
답변 감사합니다.

확인해본 결과,

현재 추가필드를 늘리기 위해 write_update.skin.php에 wr_11~15 까지를 추가했습니다.

[code]
$sql = " insert into $write_table
set wr_num = '$wr_num',
wr_reply = '$wr_reply',
wr_comment = 0,
ca_name = '$ca_name',
wr_option = '$html,$secret,$mail',
wr_subject = '$wr_subject',
wr_content = '$wr_content',
wr_seo_title = '$wr_seo_title',
wr_link1 = '$wr_link1',
wr_link2 = '$wr_link2',
wr_link1_hit = 0,
wr_link2_hit = 0,
wr_hit = 0,
wr_good = 0,
wr_nogood = 0,
mb_id = '{$member['mb_id']}',
wr_password = '$wr_password',
wr_name = '$wr_name',
wr_email = '$wr_email',
wr_homepage = '$wr_homepage',
wr_datetime = '".G5_TIME_YMDHIS."',
wr_last = '".G5_TIME_YMDHIS."',
wr_ip = '{$_SERVER['REMOTE_ADDR']}',
wr_1 = '$wr_1',
wr_2 = '$wr_2',
wr_3 = '$wr_3',
wr_4 = '$wr_4',
wr_5 = '$wr_5',
wr_6 = '$wr_6',
wr_7 = '$wr_7',
wr_8 = '$wr_8',
wr_9 = '$wr_9',
wr_10 = '$wr_10' ";
sql_query($sql);
[/code]

[code]
$sql = " update {$write_table}
set ca_name = '{$ca_name}',
wr_option = '{$html},{$secret},{$mail}',
wr_subject = '{$wr_subject}',
wr_content = '{$wr_content}',
wr_seo_title = '$wr_seo_title',
wr_link1 = '{$wr_link1}',
wr_link2 = '{$wr_link2}',
mb_id = '{$mb_id}',
wr_name = '{$wr_name}',
wr_email = '{$wr_email}',
wr_homepage = '{$wr_homepage}',
wr_1 = '{$wr_1}',
wr_2 = '{$wr_2}',
wr_3 = '{$wr_3}',
wr_4 = '{$wr_4}',
wr_5 = '{$wr_5}',
wr_6 = '{$wr_6}',
wr_7 = '{$wr_7}',
wr_8 = '{$wr_8}',
wr_9 = '{$wr_9}',
wr_10= '{$wr_10}'
{$sql_ip}
{$sql_password}
where wr_id = '{$wr['wr_id']}' ";
sql_query($sql);
[/code]

현재 다시 원상복구 시켰습니다.

여기서 저 두부분에 wr_11~15를 추가하는 순간 게시판의 글이 등록이 안됩니다.
(write.php 부분에 for문에도 15까지로 수정된 상태입니다.)

추가필드를 안쓰면 게시글 등록은 되는데,
추가필드를 추가하면 게시글 등록이 안됩니다.
엑스엠엘
4년 전
해당 게시판의 DB table에 컬럼 추가를 안 하신 듯합니다.
박강현
4년 전
답변 감사합니다.

현재 db테이블에 컬럼을 추가했습니다.

스킨에 따로 write_update.skin.php 로 만들어서 처리했습니다.

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

4년 전

일단 간단하게는 에프12 개발자 도구 키시고 스크립트 에러가 있나 살펴보세요.

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

답변에 대한 댓글 1개

박강현
4년 전
답변 감사합니다.

말씀대로 스크립트 에러는 없습니다.

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

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

로그인