'' "; $row3 = sql_fetch($sql3); if (!$row3['cnt']) continue; } } } $g5_search['tables'][] = $row['bo_table']; $g5_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 < count($s); $i++) { if (trim($s[$i]) == '') continue; $search_str = $s[$i]; // 인기검색어 insert_popular($field, $search_str); $str .= $op1; $str .= "("; $op2 = ''; // 필드의 수만큼 다중 필드 검색 가능 (필드1+필드2...) for ($k = 0; $k < count($field); $k++) { $str .= $op2; switch ($field[$k]) { case 'mb_id': case 'wr_name': $str .= "$field[$k] = '$s[$i]'"; break; case 'wr_subject': case 'wr_content': if (preg_match("/[a-zA-Z]/", $search_str)) $str .= "INSTR(LOWER({$field[$k]}), LOWER('{$search_str}'))"; else $str .= "INSTR({$field[$k]}, '{$search_str}')"; break; default: $str .= "1=0"; // 항상 거짓 break; } $op2 = " or "; } $str .= ")"; $op1 = " {$sop} "; } $str .= ")"; $sql_search = $str; $str_board_list = ""; $board_count = 0; $time1 = get_microtime(); $total_count = 0; for ($i = 0; $i < count($g5_search['tables']); $i++) { $tmp_write_table = $g5['write_prefix'] . $g5_search['tables'][$i]; $sql = " select wr_id from {$tmp_write_table} where {$sql_search} "; $result = sql_query($sql, false); $row['cnt'] = @sql_num_rows($result); $total_count += $row['cnt']; if ($row['cnt']) { $board_count++; $search_table[] = $g5_search['tables'][$i]; $read_level[] = $g5_search['read_level'][$i]; $search_table_count[] = $total_count; $sql2 = " select bo_subject, bo_mobile_subject from {$g5['board_table']} where bo_table = '{$g5_search['tables'][$i]}' "; $row2 = sql_fetch($sql2); $sch_class = ""; $sch_all = ""; if ($onetable == $g5_search['tables'][$i]) $sch_class = "class=sch_on"; else $sch_all = "class=sch_on"; $str_board_list .= '
  • ' . ((G5_IS_MOBILE && $row2['bo_mobile_subject']) ? $row2['bo_mobile_subject'] : $row2['bo_subject']) . '' . $row['cnt'] . '
  • '; } } $rows = $srows; $total_page = ceil($total_count / $rows); // 전체 페이지 계산 if ($page < 1) { $page = 1; } // 페이지가 없으면 첫 페이지 (1 페이지) $from_record = ($page - 1) * $rows; // 시작 열을 구함 for ($i = 0; $i < count($search_table); $i++) { if ($from_record < $search_table_count[$i]) { $table_index = $i; $from_record = $from_record - $search_table_count[$i - 1]; break; } } $bo_subject = []; $list = []; $k = 0; for ($idx = $table_index; $idx < count($search_table); $idx++) { $sql = " select bo_subject, bo_mobile_subject from {$g5['board_table']} where bo_table = '{$search_table[$idx]}' "; $row = sql_fetch($sql); $bo_subject[$idx] = ((G5_IS_MOBILE && $row['bo_mobile_subject']) ? $row['bo_mobile_subject'] : $row['bo_subject']); $tmp_write_table = $g5['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']) { $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(strip_tags($row['wr_content'])), 300, "…"); $content = strip_tags($row['wr_content']); $content = get_text($content, 1); $content = strip_tags($content); $content = str_replace(' ', '', $content); $content = cut_str($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'], get_text(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(G5_IS_MOBILE ? $config['cf_mobile_pages'] : $config['cf_write_pages'], $page, $total_page, $_SERVER['SCRIPT_NAME'] . '?' . $search_query . '&gr_id=' . $gr_id . '&srows=' . $srows . '&onetable=' . $onetable . '&page='); } $group_select = ''; if (!$sfl) $sfl = 'wr_subject'; if (!$sop) $sop = 'or'; include_once($search_skin_path . '/search.skin.php'); include_once('./_tail.php');