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

고수님들 코드 한번 봐주세요. 채택완료

망이망소이 8년 전 조회 4,399

https://sir.kr/g5_tip/1828?cpage=INF#c_5021">https://sir.kr/g5_tip/1828?cpage=INF#c_5021 

 

위팁의 5번항목

//5. 선택한 그룹별로 원하는 수만큼 보여줌 
//  사용법 : "분류명",게시물수, 제목글자수, 본문글자수);? >  

 

여기에 

분류명을 추가하려면

어찌해야 할까요?

 

다음은 제가 쓰고 있는 latest_group.lib.php 입니다.

</p><p><?php</p><p>if (!defined('_GNUBOARD_')) exit;</p><p> </p><p>// 최신글 추출</p><p>// $cache_time 캐시 갱신시간</p><p>function latest_group($skin_dir='', $gr_id, $rows=10, $subject_len=40, $cache_time=1, $options='')</p><p>{</p><p>    global $g5;</p><p> </p><p>    if (!$skin_dir) $skin_dir = 'basic';</p><p> </p><p>    if(preg_match('#^theme/(.+)$#', $skin_dir, $match)) {</p><p>        if (G5_IS_MOBILE) {</p><p>            $latest_skin_path = G5_THEME_MOBILE_PATH.'/'.G5_SKIN_DIR.'/latest/'.$match[1];</p><p>            if(!is_dir($latest_skin_path))</p><p>                $latest_skin_path = G5_THEME_PATH.'/'.G5_SKIN_DIR.'/latest/'.$match[1];</p><p>            $latest_skin_url = str_replace(G5_PATH, G5_URL, $latest_skin_path);</p><p>        } else {</p><p>            $latest_skin_path = G5_THEME_PATH.'/'.G5_SKIN_DIR.'/latest/'.$match[1];</p><p>            $latest_skin_url = str_replace(G5_PATH, G5_URL, $latest_skin_path);</p><p>        }</p><p>        $skin_dir = $match[1];</p><p>    } else {</p><p>        if(G5_IS_MOBILE) {</p><p>            $latest_skin_path = G5_MOBILE_PATH.'/'.G5_SKIN_DIR.'/latest/'.$skin_dir;</p><p>            $latest_skin_url  = G5_MOBILE_URL.'/'.G5_SKIN_DIR.'/latest/'.$skin_dir;</p><p>        } else {</p><p>            $latest_skin_path = G5_SKIN_PATH.'/latest/'.$skin_dir;</p><p>            $latest_skin_url  = G5_SKIN_URL.'/latest/'.$skin_dir;</p><p>        }</p><p>    }</p><p> </p><p>    $cache_fwrite = false;</p><p>    if(G5_USE_CACHE) {</p><p>        $cache_file = G5_DATA_PATH."/cache/latest-group-{$gr_id}-{$skin_dir}-{$rows}-{$subject_len}.php";</p><p> </p><p>        if(!file_exists($cache_file)) {</p><p>            $cache_fwrite = true;</p><p>        } else {</p><p>            if($cache_time > 0) {</p><p>                $filetime = filemtime($cache_file);</p><p>                if($filetime && $filetime < (G5_SERVER_TIME - 3600 * $cache_time)) {</p><p>                    @unlink($cache_file);</p><p>                    $cache_fwrite = true;</p><p>                }</p><p>            }</p><p> </p><p>            if(!$cache_fwrite)</p><p>                include($cache_file);</p><p>        }</p><p>    }</p><p> </p><p>    if(!G5_USE_CACHE || $cache_fwrite) {</p><p>        $list = array();</p><p>        $sql_common = " from {$g5['board_new_table']} a, {$g5['board_table']} b, {$g5['group_table']} c where a.bo_table = b.bo_table and b.gr_id = c.gr_id and b.bo_use_search = 1 ";</p><p>        $sql_common .= " and b.gr_id = '$gr_id' ";</p><p>        // $sql_common .= " and a.bo_table not in ('aaaa', 'bbbb') ";</p><p>        $sql_common .= " and a.wr_id = a.wr_parent ";</p><p>        $sql_order = " order by a.bn_id desc ";</p><p>        $sql = " select a.*, b.bo_subject, c.gr_subject, c.gr_id {$sql_common} {$sql_order} limit 0, {$rows}";</p><p><span class="Apple-tab-span" style="white-space:pre">		</span>$result = sql_query($sql);</p><p> </p><p><span class="Apple-tab-span" style="white-space:pre">		</span>for ($i=0; $row=sql_fetch_array($result); $i++) {</p><p> </p><p><span class="Apple-tab-span" style="white-space:pre">			</span>$sql = " select * from {$g5['board_table']} where bo_table = '{$row['bo_table']}' ";</p><p><span class="Apple-tab-span" style="white-space:pre">			</span>$board = sql_fetch($sql);</p><p><span class="Apple-tab-span" style="white-space:pre">			</span>$gr_subject = $row['gr_subject'];</p><p> </p><p><span class="Apple-tab-span" style="white-space:pre">			</span>$tmp_write_table = $g5['write_prefix'] . $row['bo_table'];</p><p><span class="Apple-tab-span" style="white-space:pre">			</span>$row2 = sql_fetch(" select * from {$tmp_write_table} where wr_id = '{$row['wr_id']}' ");</p><p> </p><p><span class="Apple-tab-span" style="white-space:pre">			</span>$list[$i] = $row2;</p><p><span class="Apple-tab-span" style="white-space:pre">			</span>$list[$i] = get_list($row2, $board, $latest_skin_url, $subject_len);</p><p><span class="Apple-tab-span" style="white-space:pre">			</span>$list[$i]['bo_subject'] = $row['bo_subject'];</p><p><span class="Apple-tab-span" style="white-space:pre">			</span>$list[$i]['bo_table'] = $row['bo_table'];</p><p><span class="Apple-tab-span" style="white-space:pre">		</span>}</p><p> </p><p>        if($cache_fwrite) {</p><p>            $handle = fopen($cache_file, 'w');</p><p>            $cache_content = "<?php\nif (!defined('_GNUBOARD_')) exit;\n\$gr_subject='".$gr_subject."';\n\$list=".var_export($list, true)."?>";</p><p>            fwrite($handle, $cache_content);</p><p>            fclose($handle);</p><p>        }</p><p>    }</p><p> </p><p>    ob_start();</p><p>    include $latest_skin_path.'/latest.skin.php';</p><p>    $content = ob_get_contents();</p><p>    ob_end_clean();</p><p> </p><p>    return $content;</p><p>}</p><p> </p><p> </p><p> </p><p>?></p><p>

 

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

답변 1개

채택된 답변
+20 포인트
8년 전

그룹내의 모든 게시판에서 동일한 분류를 사용하고 있다는 것인가요?

어쨌거나 위 소스에 약간 추가하여 같은 분류의 게시물 10개를 추출한다는 것은 아주 어렵습니다

 

$g5['board_new_table']테이블에 분류필드를 하나 추가하여 등록시 분류를 기록해두는

방법으로 하면 쉽게 해결 되겠습니다

이렇게 하면 58행 다음줄에 아래 코드만 추가하면 되겠습니다

if($option) $sql_common .= "a.ca_name = '$options' ";

호출시 빨강부분은 빼버리고 마지막에 분류를 추가하면 됩니다

latest_group(~~~~,'여기에 분류');

 

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

답변에 대한 댓글 1개

망이망소이
8년 전
감사합니다. 균이님. 죄송한데 제가 질문에 사용한 팁을 다른걸 얘기했습니다.
https://sir.kr/g5_tip/1828?cpage=INF#c_5021 이 팁은 사용하지 않았구요.(착각)
이것을 이용중입니다.
https://sir.kr/g5_skin/9863?sca=%EC%B5%9C%EC%8B%A0%EA%B8%80&sfl=wr_subject%7C%7Cwr_content&stx=%EA%B7%B8%EB%A3%B9

$g5['board_new_table'] 필드명 추가하고 말씀해주신데로 해봤는데 아직... ㅜㅜ

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

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

로그인