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

인기검색어 질문

작은생각 6년 전 조회 2,468

사이트에서 검색을 하면 인기검색어 노출이

 http://masta119.bcpark.net/html/gblog/bbs/search.php?sfl=wr_subject||wr_content&sop=and&stx=ZZZ%C2%84ZZ%C2%9CZZZ%C2%9A%5C%5C%5C%5C%5C%5C%5C%5C%5C%5C%5C%5C%5C%5C%5C%5C%5C%5C%5C%5C%5C%5C%5C%5C%5C%5C%5C%5C%5C%5C%5C%5C%5C%5C%5C%5C%5C%5C%5C">ZZZ혙ZZ혵ZZZ혳 이런 문자로 나옵니다.

 

아래 소스는 search.php 소스 입니다.

사이트는 http://masta119.bcpark.net

-------------------------------------------------------------------------------------------------

 

$g4[title] = "검색 : " . $stx; include_once("./_head.php"); ?>

border=0>
>

    unset($g4_search[tables]);     unset($g4_search[read_level]);     $sql = " select gr_id, bo_table, bo_read_level from $g4[board_table] where bo_use_search = '1' and bo_list_level <= '$member[mb_level]' ";     //            and bo_read_level <= '$member[mb_level]' ";     if ($gr_id)         $sql .= " and gr_id = '$gr_id' ";     if ($onetable) // 하나의 게시판만 검색한다면         $sql .= " and bo_table = '$onetable' ";     $sql .= " order by bo_order_search, gr_id, bo_table ";     $result = sql_query($sql);     for ($i=0; $row=sql_fetch_array($result); $i++)     {         if ($is_admin != "super")         {             // 그룹접근 사용에 대한 검색 차단             $sql2 = " select gr_use_access, gr_admin from $g4[group_table] where gr_id = '$row[gr_id]' ";             $row2 = sql_fetch($sql2);             // 그룹접근을 사용한다면             if ($row2[gr_use_access])             {                 // 그룹관리자가 있으며 현재 회원이 그룹관리자라면 통과                 if ($row2[gr_admin] && $row2[gr_admin] == $member[mb_id])                     ;                 else                 {                     $sql3 = " select count(*) as cnt from $g4[group_member_table] where gr_id = '$row[gr_id]' and mb_id = '$member[mb_id]' and mb_id <> '' ";                     $row3 = sql_fetch($sql3);                     if (!$row3[cnt])                         continue;                 }             }         }         $g4_search[tables][] = $row[bo_table];         $g4_search[read_level][] = $row[bo_read_level];     }

    $search_query = "sfl=".urlencode($sfl)."&stx=".urlencode($stx)."&sop=$sop";

    $text_stx = get_text(stripslashes($stx));

    $op1 = "";

    // 검색어를 구분자로 나눈다. 여기서는 공백     $s = explode(" ", strip_tags($stx));

    // 검색필드를 구분자로 나눈다. 여기서는 +     $field = explode("||", trim($sfl));

    $str = "(";     for ($i=0; $i

        $op1 = " $sop ";

        // 인기검색어         $sql = " insert into $g4[popular_table] set pp_word = '$search_str', pp_date = '$g4[time_ymd]', pp_ip = '$_SERVER[REMOTE_ADDR]' ";         sql_query($sql, FALSE);     }     $str .= ")";

    //$sql_search = $str . " and wr_option not like '%secret%' "; // 비밀글은 제외     $sql_search = $str;

    $str_board_list = "";     $board_count = 0;

    $time1 = get_microtime();

    $total_count = 0;     for ($i=0; $i

        //$sql = " select count(*) as cnt from $tmp_write_table where $sql_search ";         //$row = sql_fetch($sql);

        $total_count += $row[cnt];         if ($row[cnt])         {             $board_count++;             $search_table[] = $g4_search[tables][$i];             $read_level[]   = $g4_search[read_level][$i];             $search_table_count[] = $total_count;

            $sql2 = " select bo_subject from $g4[board_table] where bo_table = '{$g4_search[tables][$i]}' ";             $row2 = sql_fetch($sql2);             $str_board_list .= "

  • $row2[bo_subject] ($row[cnt])";         }     }

        $rows = $srows;     $total_page  = ceil($total_count / $rows);  // 전체 페이지 계산     if ($page == "") { $page = 1; } // 페이지가 없으면 첫 페이지 (1 페이지)     $from_record = ($page - 1) * $rows; // 시작 열을 구함

        for ($i=0; $i

        $bo_subject = array();     $list = array();

        $k=0;     for ($idx=$table_index; $idx

            $tmp_write_table = $g4[write_prefix] . $search_table[$idx];

            $sql = " select * from $tmp_write_table where $sql_search order by wr_id desc limit $from_record, $rows ";         $result = sql_query($sql);         for ($i=0; $row=sql_fetch_array($result); $i++)         {             // 검색어까지 링크되면 게시판 부하가 일어남             $list[$idx][$i] = $row;             $list[$idx][$i][href] = "./board.php?bo_table=$search_table[$idx]&wr_id=$row[wr_parent]";

                if ($row[wr_is_comment])             {                 $link .= "#c{$row[wr_id]}";                 $sql2 = " select wr_subject, wr_option from $tmp_write_table where wr_id = '$row[wr_parent]' ";                 $row2 = sql_fetch($sql2);                 //$row[wr_subject] = $row2[wr_subject];                 $row[wr_subject] = get_text($row2[wr_subject]);             }

                // 비밀글은 검색 불가             if (strstr($row[wr_option].$row2[wr_option], "secret"))                 $row[wr_content] = "[비밀글 입니다.]";

                $subject = get_text($row[wr_subject]);             if (strstr($sfl, "wr_subject"))                 $subject = search_font($stx, $subject);

                if ($read_level[$idx] <= $member[mb_level])             {                 $content = cut_str(get_text($row[wr_content]),300,"…");                 if (strstr($sfl, "wr_content"))                     $content = search_font($stx, $content);             }             else                 $content = '';

                $list[$idx][$i][subject] = $subject;             $list[$idx][$i][content] = $content;             $list[$idx][$i][name] = get_sideview($row[mb_id], cut_str($row[wr_name], $config[cf_cut_name]), $row[wr_email], $row[wr_homepage]);                         $k++;             if ($k >= $rows)                 break;         }         sql_free_result($result);                 if ($k >= $rows)             break;

            $from_record = 0;     }

        $write_pages = get_paging($config[cf_write_pages], $page, $total_page, "$_SERVER[PHP_SELF]?$search_query&gr_id=$gr_id&srows=$srows&onetable=$onetable&page=");

        echo ""; }

    $group_select = "";

    if (!$sfl) $sfl = "wr_subject"; if (!$sop) $sop = "or";

    $search_skin_path = "$g4[path]/skin/search/$config[cf_search_skin]"; include_once("$search_skin_path/search.skin.php");

    ?>

  • valign=top bgcolor=>

    include_once("./_tail.php"); ?>

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

    답변 1개

    6년 전

    검색어 스킨과 홈피의  문자셋을 확인해 보셔야 할 듯 합니다.

    홈피의 문자셋은 euc-kr로 되어 있는데,

    검색어 관련 파일들, 스킨들은 UTF-8 이거나 다른 문자셋 이 아닐까 싶네요.

    더불어, DB의 문자셋도 같이 확인해보시길..

     

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

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

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

    로그인

    © 2025 SIRSOFT. All rights reserved.