답변 3개
채택된 답변
+20 포인트
1년 전
다음과 같이 하시면 되지 않을까 합니다.
</p>
<p><?php
// $bo_tables 테이블들 사이 콤마(,) 단위로 구분해서 넣을 것, 콤마 사이에 공백 없이 (ex aaa,bbb,)
function latest_all($skin_dir='', $bo_tables, $rows=10, $subject_len=40, $cache_time=1, $options='')
{</p>
<p> global $g5;</p>
<p> if (!$skin_dir) $skin_dir = 'basic';</p>
<p> if(preg_match('#^theme/(.+)$#', $skin_dir, $match)) {
if (G5_IS_MOBILE) {
$latest_skin_path = G5_THEME_MOBILE_PATH.'/'.G5_SKIN_DIR.'/latest/'.$match[1];
if(!is_dir($latest_skin_path))
$latest_skin_path = G5_THEME_PATH.'/'.G5_SKIN_DIR.'/latest/'.$match[1];
$latest_skin_url = str_replace(G5_PATH, G5_URL, $latest_skin_path);
} else {
$latest_skin_path = G5_THEME_PATH.'/'.G5_SKIN_DIR.'/latest/'.$match[1];
$latest_skin_url = str_replace(G5_PATH, G5_URL, $latest_skin_path);
}
$skin_dir = $match[1];
} else {
if(G5_IS_MOBILE) {
$latest_skin_path = G5_MOBILE_PATH.'/'.G5_SKIN_DIR.'/latest/'.$skin_dir;
$latest_skin_url = G5_MOBILE_URL.'/'.G5_SKIN_DIR.'/latest/'.$skin_dir;
} else {
$latest_skin_path = G5_SKIN_PATH.'/latest/'.$skin_dir;
$latest_skin_url = G5_SKIN_URL.'/latest/'.$skin_dir;
}
}</p>
<p> $list = array();
$sql_common = " from {$g5['board_new_table']} a where find_in_set(a.bo_table, '{$bo_tables}')";
$sql_common .= " and a.wr_id = a.wr_parent ";
$sql_order = " order by a.bn_id desc ";
$sql = " select a.* {$sql_common} {$sql_order}";</p>
<p> $result = sql_query($sql);
$row_count = sql_num_rows($result);</p>
<p> if ($row_count > 0) {
$rand_row = rand(0, $row_count - 1);
$sql = " select a.* {$sql_common} {$sql_order} limit {$rand_row}, 1";
$result = sql_query($sql);</p>
<p> $row = sql_fetch_array($result);</p>
<p> $sql = " select * from {$g5['board_table']} where bo_table = '{$row['bo_table']}' ";</p>
<p> $board = sql_fetch($sql);</p>
<p> $tmp_write_table = $g5['write_prefix'] . $row['bo_table'];
$row2 = sql_fetch(" select * from {$tmp_write_table} where wr_id = '{$row['wr_id']}' ");</p>
<p> $list[0] = get_list($row2, $board, $latest_skin_url, $subject_len);
$list[0]['bo_subject'] = $row['bo_subject'];
$list[0]['bo_table'] = $row['bo_table'];
}</p>
<p> ob_start();
include $latest_skin_path.'/latest.skin.php';
$content = ob_get_contents();
ob_end_clean();</p>
<p> return $content;
}
?>
로그인 후 평가할 수 있습니다
답변에 대한 댓글 4개
a
angpang
1년 전
�
웹메이킹
1년 전
$i가 제대로 정의되었고 반복문 안에서 올바르게 증가되는지 확인해 보세요 $i는 일반적으로 여러 항목을 반복 처리하기 위해 반복문 안에서 사용되어야 합니다.
디버깅을 해서 에러의 원인을 찾아서 해결 할 수 있을것으로 보입니다.
[code]
for ($i = 0; $i < $row_count; $i++) {
// ... 기존의 코드 ...
// 디버깅 문장 추가
echo "디버그 정보: i=$i, bo_subject={$list[$i]['bo_subject']}, bo_table={$list[$i]['bo_table']}<br>";
// ... 반복문의 나머지 부분 ...
}
[/code]
디버깅을 해서 에러의 원인을 찾아서 해결 할 수 있을것으로 보입니다.
[code]
for ($i = 0; $i < $row_count; $i++) {
// ... 기존의 코드 ...
// 디버깅 문장 추가
echo "디버그 정보: i=$i, bo_subject={$list[$i]['bo_subject']}, bo_table={$list[$i]['bo_table']}<br>";
// ... 반복문의 나머지 부분 ...
}
[/code]
a
angpang
1년 전
lib파일, latest파일 어디에도
for ($i = 0; $i < $row_count; $i++) {
라는 소스가 안보여서요..제가 초보라 디버딩 어디를 만져야될지..^^;답변 감사합니다..
for ($i = 0; $i < $row_count; $i++) {
라는 소스가 안보여서요..제가 초보라 디버딩 어디를 만져야될지..^^;답변 감사합니다..
�
웹메이킹
1년 전
위 소스 상단에
for ($i = 0; $i < $row_count; $i++) {
// ... 기존의 코드 ...
// 디버깅 문장 추가
echo "디버그 정보: i=$i, bo_subject={$list[$i]['bo_subject']}, bo_table={$list[$i]['bo_table']}<br>";
// ... 반복문의 나머지 부분 ...
}
이부분을 적용해서 $i 값이 제대로 적용되어 있는지 확인해 보시라는 거였습니다.
$i 값이 정의되지 않았다면 반복문에서 정의를 해주셔야 $list[$i]['bo_subject'] = $board['bo_subject']; 이렇게 했을때 정상 출력이 됩니다.
for ($i = 0; $i < $row_count; $i++) {
// ... 기존의 코드 ...
// 디버깅 문장 추가
echo "디버그 정보: i=$i, bo_subject={$list[$i]['bo_subject']}, bo_table={$list[$i]['bo_table']}<br>";
// ... 반복문의 나머지 부분 ...
}
이부분을 적용해서 $i 값이 제대로 적용되어 있는지 확인해 보시라는 거였습니다.
$i 값이 정의되지 않았다면 반복문에서 정의를 해주셔야 $list[$i]['bo_subject'] = $board['bo_subject']; 이렇게 했을때 정상 출력이 됩니다.
댓글을 작성하려면 로그인이 필요합니다.
댓글을 작성하려면 로그인이 필요합니다.
답변을 작성하려면 로그인이 필요합니다.
로그인
게시판 제목 추출때문에
$list[0]['bo_subject'] = $row['bo_subject'];를
$list[$i]['bo_subject'] = $board['bo_subject']; 이렇게 바꿨더니.. 로딩되고 사이트가 안열리네요..방법이 있는지요